/* ============================================
   ASPARTNER — 福岡投資不動産・相続対策
   Premium Navy × Gold · 富裕層向け信頼設計
   調査ベース: 日本財託・武蔵・シノケン・PA
   ============================================ */

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

:root {
  /* === Premium Navy/Gold Palette === */
  --ink-deep: #0a1729;
  --ink: #112545;
  --ink-mid: #1d3865;
  --ink-soft: #3a5685;
  --ink-mist: #6a85ad;

  --gold-deep: #826335;
  --gold: #b08855;
  --gold-light: #ccaa78;
  --gold-bright: #e2c79a;

  --paper: #faf7f0;
  --paper-warm: #f3ede0;
  --cream: #fbf9f4;

  --accent-vermillion: #b08855;      /* ゴールド統一(旧朱色からシフト) */
  --accent-vermillion-dark: #826335;

  --line-soft: #e2dccd;
  --line: #c9c0aa;
  --line-strong: #a89e85;

  --text: #28324a;
  --text-mid: #4a556e;
  --text-soft: #6e7689;
  --text-light: #9aa0b0;

  --white: #ffffff;
  --black: #000000;
  --line-green: #06c755;

  /* Typography */
  --mincho-display: "Shippori Mincho B1", "Noto Serif JP", "Yu Mincho", serif;
  --mincho: "Noto Serif JP", "Yu Mincho", serif;
  --serif-en: "EB Garamond", "Cormorant Garamond", Georgia, serif;
  --sans: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Hiragino Sans", sans-serif;

  /* Spacing */
  --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px;
  --sp-5: 24px; --sp-6: 32px; --sp-7: 48px; --sp-8: 64px;
  --sp-9: 80px; --sp-10: 96px; --sp-11: 128px; --sp-12: 160px;

  --t: 0.35s cubic-bezier(0.22, 0.61, 0.36, 1);
  --t-fast: 0.18s ease;

  --shadow-sm: 0 2px 12px rgba(10, 23, 41, 0.06);
  --shadow: 0 8px 28px rgba(10, 23, 41, 0.10);
  --shadow-md: 0 16px 48px rgba(10, 23, 41, 0.14);
  --shadow-lg: 0 32px 80px rgba(10, 23, 41, 0.20);
}

body {
  font-family: var(--mincho);
  color: var(--text);
  background: var(--cream);
  line-height: 2;
  font-size: 15px;
  letter-spacing: 0.04em;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "palt" 1;
}

a { color: inherit; text-decoration: none; transition: color var(--t-fast); }
img { max-width: 100%; display: block; }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--mincho-display);
  font-weight: 500;
  color: var(--ink-deep);
  line-height: 1.45;
  letter-spacing: 0.02em;
}

::selection { background: var(--gold); color: var(--paper); }

/* ============================================
   Container
   ============================================ */
.container { max-width: 1280px; margin: 0 auto; padding: 0 var(--sp-7); }
.container-narrow { max-width: 960px; margin: 0 auto; padding: 0 var(--sp-7); }
.container-wide { max-width: 1440px; margin: 0 auto; padding: 0 var(--sp-7); }

/* ============================================
   Buttons (3-tier CTA system)
   ============================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  padding: 18px 36px;
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: all var(--t);
  position: relative;
  text-align: center;
  white-space: nowrap;
}

/* Primary CTA — 個別相談 (深いネイビー + 金枠) */
.btn-primary {
  background: var(--ink-deep);
  color: var(--paper);
  border: 1px solid var(--gold);
  padding: 22px 44px;
  font-size: 14px;
  position: relative;
}
.btn-primary::before {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px solid rgba(176, 136, 85, 0.4);
  pointer-events: none;
  transition: inset var(--t);
}
.btn-primary:hover {
  background: var(--ink);
  color: var(--paper);
  transform: translateY(-2px);
  box-shadow: 0 20px 40px -16px rgba(10, 23, 41, 0.5);
}
.btn-primary:hover::before { inset: 6px; border-color: var(--gold-light); }

/* Gold CTA — 資料請求/ROA */
.btn-gold {
  background: var(--gold);
  color: var(--paper);
  padding: 22px 44px;
  font-size: 14px;
  letter-spacing: 0.18em;
}
.btn-gold:hover {
  background: var(--gold-deep);
  color: var(--paper);
  transform: translateY(-2px);
  box-shadow: 0 20px 40px -16px rgba(130, 99, 53, 0.5);
}

/* Outline CTA */
.btn-outline {
  background: transparent;
  color: var(--ink-deep);
  border: 1px solid var(--ink-deep);
}
.btn-outline:hover { background: var(--ink-deep); color: var(--paper); }

/* Ghost (on dark) */
.btn-ghost {
  background: transparent;
  color: var(--paper);
  border: 1px solid rgba(255, 255, 255, 0.35);
}
.btn-ghost:hover { border-color: var(--gold-bright); color: var(--gold-bright); }

/* Vermillion */
.btn-vermillion {
  background: var(--accent-vermillion);
  color: var(--paper);
}
.btn-vermillion:hover { background: var(--accent-vermillion-dark); color: var(--paper); transform: translateY(-2px); }

/* LINE */
.btn-line {
  background: var(--line-green);
  color: var(--white);
  letter-spacing: 0.1em;
}
.btn-line:hover { background: #05a847; color: var(--white); }

.btn-sm { padding: 12px 22px; font-size: 12px; }
.btn-lg { padding: 24px 56px; font-size: 15px; }
.btn-xl { padding: 28px 64px; font-size: 16px; }

.btn-arrow::after {
  content: "→";
  font-family: var(--serif-en);
  margin-left: 4px;
  transition: transform var(--t);
}
.btn-arrow:hover::after { transform: translateX(6px); }

/* ============================================
   Top notification bar
   ============================================ */
.top-bar {
  background: var(--ink-deep);
  color: var(--paper-warm);
  padding: 9px var(--sp-7);
  text-align: center;
  font-family: var(--mincho);
  font-size: 12px;
  letter-spacing: 0.18em;
  border-bottom: 1px solid rgba(176, 136, 85, 0.25);
}
.top-bar em {
  font-style: normal;
  color: var(--gold-bright);
  margin: 0 var(--sp-2);
}

/* ============================================
   Header
   ============================================ */
.site-header {
  background: rgba(250, 247, 240, 0.95);
  backdrop-filter: blur(14px) saturate(160%);
  -webkit-backdrop-filter: blur(14px) saturate(160%);
  position: sticky;
  top: 0;
  z-index: 100;
  border-bottom: 1px solid var(--line-soft);
}
.header-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--sp-7);
  padding: var(--sp-5) var(--sp-7);
  max-width: 1440px;
  margin: 0 auto;
}
.logo { line-height: 1; text-decoration: none; }
.logo-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.32em;
  display: block;
  margin-bottom: 5px;
  font-weight: 500;
}
.logo-jp {
  font-family: var(--mincho-display);
  font-size: 22px;
  color: var(--ink-deep);
  font-weight: 500;
  letter-spacing: 0.1em;
  display: block;
}
.logo-img {
  display: block;
  height: 56px;
  width: auto;
  max-width: 300px;
  object-fit: contain;
  image-rendering: -webkit-optimize-contrast;
  -webkit-user-drag: none;
}
@media (max-width: 768px) {
  .logo-img { height: 40px; max-width: 200px; }
}
.global-nav { display: flex; justify-content: center; gap: var(--sp-7); }
.global-nav a {
  font-family: var(--mincho);
  color: var(--ink-deep);
  font-size: 14px;
  letter-spacing: 0.12em;
  padding: var(--sp-3) 0;
  position: relative;
}
.global-nav a::after {
  content: "";
  position: absolute;
  bottom: 4px;
  left: 50%;
  width: 0;
  height: 1px;
  background: var(--gold);
  transition: all var(--t);
  transform: translateX(-50%);
}
.global-nav a:hover, .global-nav a.active { color: var(--gold-deep); }
.global-nav a:hover::after, .global-nav a.active::after { width: 100%; }
.header-right { display: flex; align-items: center; gap: var(--sp-5); }
.header-phone { text-align: right; line-height: 1.2; }
.header-phone-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 9.5px;
  color: var(--text-soft);
  letter-spacing: 0.3em;
  font-weight: 500;
}
.header-phone-num {
  font-family: var(--serif-en);
  font-size: 19px;
  color: var(--ink-deep);
  font-weight: 500;
  letter-spacing: 0.06em;
  margin-top: 3px;
}

/* ============================================
   HERO — Editorial + Big Numbers
   調査結果反映: 数字重視・3秒で信頼確立
   ============================================ */
.hero {
  position: relative;
  min-height: 86vh;
  display: flex;
  align-items: center;
  padding: var(--sp-9) var(--sp-7);
  background: var(--ink-deep);
  color: var(--paper);
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(110deg, rgba(10, 23, 41, 0.94) 25%, rgba(17, 37, 69, 0.78) 65%, rgba(29, 56, 101, 0.45) 100%),
    url('https://images.unsplash.com/photo-1590559899731-a382839e5549?w=2400&q=88&auto=format&fit=crop');
  background-size: cover;
  background-position: center 35%;
}
.hero::after {
  content: "";
  position: absolute;
  inset: var(--sp-7);
  border: 1px solid rgba(176, 136, 85, 0.18);
  pointer-events: none;
}
.hero-inner {
  position: relative;
  z-index: 1;
  max-width: 1240px;
  margin: 0 auto;
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: var(--sp-9);
  align-items: center;
}
.hero-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 13px;
  letter-spacing: 0.4em;
  color: var(--gold-bright);
  margin-bottom: var(--sp-6);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-weight: 500;
}
.hero-en::before {
  content: "";
  width: 56px;
  height: 1px;
  background: var(--gold);
  display: block;
}
.hero-h1 {
  font-family: var(--mincho-display);
  font-size: clamp(38px, 5vw, 76px);
  font-weight: 500;
  line-height: 1.32;
  color: var(--gold-bright);
  margin-bottom: var(--sp-7);
  letter-spacing: 0.025em;
}
.hero-h1 em {
  font-style: normal;
  color: var(--gold-bright);
  font-weight: 600;
  text-shadow: 0 0 24px rgba(226, 199, 154, 0.25);
}
.hero-h1 .accent {
  display: block;
  font-size: 0.34em;
  font-family: var(--serif-en);
  font-style: italic;
  color: var(--gold-light);
  letter-spacing: 0.25em;
  margin-top: var(--sp-5);
  font-weight: 500;
}
.hero-sub {
  font-family: var(--mincho);
  font-size: 16px;
  line-height: 2.2;
  color: rgba(250, 247, 240, 0.88);
  margin-bottom: var(--sp-8);
  max-width: 580px;
  letter-spacing: 0.06em;
}
.hero-sub strong { color: var(--gold-bright); font-weight: 500; }

.hero-cta-row { display: flex; flex-wrap: wrap; gap: var(--sp-3); align-items: center; }

.hero-meta {
  margin-top: var(--sp-6);
  font-family: var(--mincho);
  font-size: 12px;
  color: rgba(250, 247, 240, 0.6);
  letter-spacing: 0.2em;
}
.hero-meta span { margin-right: var(--sp-5); }
.hero-meta span::before { content: "— "; color: var(--gold); }

/* Hero stat panel — 信頼の数字 */
.hero-stats {
  background: rgba(10, 23, 41, 0.65);
  border: 1px solid rgba(176, 136, 85, 0.28);
  backdrop-filter: blur(10px);
  padding: var(--sp-7);
}
.hero-stats-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  letter-spacing: 0.4em;
  color: var(--gold-bright);
  text-align: center;
  padding-bottom: var(--sp-5);
  margin-bottom: var(--sp-6);
  border-bottom: 1px solid rgba(176, 136, 85, 0.3);
  font-weight: 500;
}
.hero-stat-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}
.hero-stat {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  gap: var(--sp-4);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid rgba(176, 136, 85, 0.12);
}
.hero-stat:last-child { border-bottom: none; padding-bottom: 0; }
.hero-stat-label {
  font-family: var(--mincho);
  font-size: 13px;
  color: rgba(250, 247, 240, 0.75);
  letter-spacing: 0.18em;
}
.hero-stat-value {
  font-family: var(--serif-en);
  font-size: 36px;
  font-weight: 500;
  color: var(--gold-bright);
  line-height: 1;
  letter-spacing: -0.02em;
}
.hero-stat-value small {
  font-family: var(--mincho);
  font-size: 0.42em;
  color: var(--gold-light);
  margin-left: 4px;
  letter-spacing: 0.15em;
  font-weight: 400;
}

.hero-scroll {
  position: absolute;
  bottom: var(--sp-7);
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 10px;
  letter-spacing: 0.4em;
  color: rgba(250, 247, 240, 0.5);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-3);
  z-index: 2;
}
.hero-scroll::after {
  content: "";
  width: 1px;
  height: 28px;
  background: linear-gradient(to bottom, var(--gold-bright), transparent);
  animation: scrollHint 2s ease-in-out infinite;
}
@keyframes scrollHint {
  0%, 100% { transform: scaleY(0.5); transform-origin: top; }
  50% { transform: scaleY(1); }
}

/* ============================================
   Sections
   ============================================ */
.section { padding: var(--sp-11) var(--sp-7); position: relative; }
.section-light { background: var(--paper); }
.section-cream { background: var(--cream); }
.section-warm { background: var(--paper-warm); }
.section-dark { background: var(--ink-deep); color: var(--paper); }

.section-head {
  text-align: center;
  margin-bottom: var(--sp-10);
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
}
.section-head-left { text-align: left; max-width: 720px; margin-left: 0; }

.chapter-mark {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  font-family: var(--mincho-display);
  color: var(--gold);
  font-size: 13px;
  letter-spacing: 0.45em;
  margin-bottom: var(--sp-6);
  font-weight: 400;
}
.chapter-mark::before, .chapter-mark::after {
  content: "";
  display: block;
  width: 32px;
  height: 1px;
  background: var(--gold);
}
.section-head-left .chapter-mark::after { display: none; }

.section-title {
  font-family: var(--mincho-display);
  font-size: clamp(32px, 4.2vw, 54px);
  font-weight: 500;
  line-height: 1.4;
  color: var(--ink-deep);
  letter-spacing: 0.025em;
}
.section-dark .section-title { color: var(--paper); }
.section-title em {
  font-style: normal;
  color: var(--gold);
  border-bottom: 1px solid var(--gold);
  padding-bottom: 4px;
}
.section-dark .section-title em { color: var(--gold-bright); border-bottom-color: var(--gold-bright); }

.section-lead {
  font-family: var(--mincho);
  font-size: 15.5px;
  line-height: 2.3;
  color: var(--text-mid);
  margin-top: var(--sp-5);
  letter-spacing: 0.05em;
}
.section-dark .section-lead { color: rgba(250, 247, 240, 0.78); }

/* ============================================
   Three Strengths
   ============================================ */
.strengths-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-7);
  max-width: 1240px;
  margin: 0 auto;
}
.strength-card {
  background: var(--white);
  padding: var(--sp-8);
  border: 1px solid var(--line-soft);
  transition: all var(--t);
  position: relative;
}
.strength-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--t);
}
.strength-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-md);
  border-color: var(--gold-light);
}
.strength-card:hover::before { transform: scaleX(1); }
.strength-num {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 14px;
  color: var(--gold);
  letter-spacing: 0.32em;
  margin-bottom: var(--sp-3);
  font-weight: 500;
}
.strength-num strong {
  font-family: var(--mincho-display);
  font-style: normal;
  font-size: 60px;
  color: var(--ink-deep);
  display: block;
  line-height: 1;
  margin: var(--sp-3) 0 var(--sp-5);
  letter-spacing: 0.02em;
  font-weight: 500;
}
.strength-title {
  font-family: var(--mincho-display);
  font-size: 22px;
  font-weight: 500;
  color: var(--ink-deep);
  margin-bottom: var(--sp-5);
  line-height: 1.55;
  letter-spacing: 0.02em;
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--line-soft);
}
.strength-title em { color: var(--gold-deep); font-style: normal; }
.strength-body {
  font-family: var(--mincho);
  font-size: 14px;
  line-height: 2.2;
  color: var(--text-mid);
  letter-spacing: 0.04em;
}
.strength-tag-row {
  margin-top: var(--sp-5);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--line-soft);
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}
.strength-tag {
  font-family: var(--mincho);
  font-size: 11px;
  color: var(--gold-deep);
  background: var(--paper-warm);
  padding: 4px 12px;
  letter-spacing: 0.1em;
  border: 1px solid var(--line);
}

/* ============================================
   Big Numbers — 実績数字パネル(調査結果重視)
   ============================================ */
.big-numbers-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  max-width: 1240px;
  margin: 0 auto;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.big-number {
  padding: var(--sp-9) var(--sp-5);
  text-align: center;
  border-right: 1px solid var(--line-soft);
  position: relative;
}
.big-number:last-child { border-right: none; }
.big-number::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 0;
  height: 2px;
  background: var(--gold);
  transition: width var(--t);
  transform: translateX(-50%);
}
.big-number:hover::before { width: 56px; }
.big-number-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11.5px;
  color: var(--gold);
  letter-spacing: 0.32em;
  margin-bottom: var(--sp-4);
  font-weight: 500;
}
.big-number-value {
  font-family: var(--serif-en);
  font-size: clamp(48px, 5.5vw, 88px);
  font-weight: 500;
  color: var(--ink-deep);
  line-height: 1;
  letter-spacing: -0.04em;
}
.big-number-value small {
  font-family: var(--mincho);
  font-size: 0.32em;
  color: var(--ink-mid);
  margin-left: 6px;
  letter-spacing: 0.18em;
  font-weight: 400;
}
.big-number-label {
  font-family: var(--mincho);
  color: var(--ink-deep);
  font-size: 13px;
  margin-top: var(--sp-5);
  letter-spacing: 0.25em;
}
.big-numbers-footer {
  text-align: center;
  margin-top: var(--sp-7);
  font-family: var(--mincho);
  font-size: 11.5px;
  color: var(--text-soft);
  letter-spacing: 0.2em;
  line-height: 2;
}

/* ============================================
   Fukuoka Thesis — 福岡市の理由
   ============================================ */
.fukuoka-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-9);
  max-width: 1280px;
  margin: 0 auto;
  align-items: stretch;
}
.fukuoka-image {
  background-image:
    linear-gradient(to bottom, rgba(10,23,41,0.18), rgba(10,23,41,0.4)),
    url('https://images.unsplash.com/photo-1554188248-986adbb73be4?w=1400&q=88&auto=format&fit=crop');
  background-size: cover;
  background-position: center;
  min-height: 580px;
  position: relative;
}
.fukuoka-image::before {
  content: "";
  position: absolute;
  inset: 20px;
  border: 1px solid rgba(250, 247, 240, 0.22);
}
.fukuoka-image-caption {
  position: absolute;
  bottom: var(--sp-7);
  left: var(--sp-7);
  color: var(--paper);
  font-family: var(--mincho-display);
  font-size: 26px;
  letter-spacing: 0.2em;
  line-height: 1.5;
}
.fukuoka-image-caption small {
  display: block;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold-bright);
  letter-spacing: 0.32em;
  margin-top: var(--sp-3);
  font-weight: 500;
}
.fukuoka-text { padding: var(--sp-3) 0; }
.fukuoka-stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin-top: var(--sp-7);
  border-top: 1px solid var(--line);
}
.fukuoka-stat {
  padding: var(--sp-6) var(--sp-5);
  border-bottom: 1px solid var(--line-soft);
  border-right: 1px solid var(--line-soft);
}
.fukuoka-stat:nth-child(2n) { border-right: none; }
.fukuoka-stat:nth-last-child(-n+2) { border-bottom: 1px solid var(--line); }
.fukuoka-stat-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 10.5px;
  color: var(--gold);
  letter-spacing: 0.3em;
  margin-bottom: var(--sp-3);
  font-weight: 500;
}
.fukuoka-stat-num {
  font-family: var(--serif-en);
  font-size: 44px;
  color: var(--ink-deep);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.03em;
}
.fukuoka-stat-num small {
  font-family: var(--mincho);
  font-size: 0.4em;
  color: var(--ink-mid);
  margin-left: 3px;
  font-weight: 400;
  letter-spacing: 0.12em;
}
.fukuoka-stat-title {
  font-family: var(--mincho);
  font-size: 13.5px;
  color: var(--ink-deep);
  margin-top: var(--sp-3);
  letter-spacing: 0.1em;
  font-weight: 500;
}
.fukuoka-stat-desc {
  font-family: var(--mincho);
  font-size: 11.5px;
  color: var(--text-soft);
  line-height: 1.85;
  margin-top: var(--sp-2);
  letter-spacing: 0.04em;
}

/* ============================================
   Voices (お客様の声 — 写真・職業・実績)
   ============================================ */
.voices-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-7);
  max-width: 1200px;
  margin: 0 auto;
}
.voice-card {
  background: var(--white);
  padding: var(--sp-8);
  border: 1px solid var(--line-soft);
  transition: var(--t);
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: var(--sp-7);
  align-items: start;
}
.voice-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--gold-light); }
.voice-photo {
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--ink-soft), var(--ink-mid));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold-bright);
  font-family: var(--mincho-display);
  font-size: 22px;
  font-weight: 500;
  border: 2px solid var(--gold);
  overflow: hidden;
  flex-shrink: 0;
}
.voice-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 28%;
  display: block;
  filter: contrast(1.04) saturate(1.05);
}
.voice-content { padding-top: var(--sp-2); }
.voice-tag {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.25em;
  margin-bottom: var(--sp-3);
  font-weight: 500;
}
.voice-quote {
  font-family: var(--mincho-display);
  font-size: 19px;
  font-weight: 500;
  color: var(--ink-deep);
  line-height: 1.7;
  margin-bottom: var(--sp-4);
  letter-spacing: 0.02em;
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--gold);
}
.voice-quote em {
  font-style: normal;
  background: linear-gradient(transparent 60%, rgba(176, 136, 85, 0.18) 60%);
  padding: 0 4px;
}
.voice-excerpt {
  font-family: var(--mincho);
  font-size: 13px;
  line-height: 1.95;
  color: var(--ink-mid);
  letter-spacing: 0.04em;
  margin: 0 0 var(--sp-4);
}
.voice-excerpt strong {
  color: var(--ink-deep);
  font-weight: 500;
  background: linear-gradient(transparent 60%, rgba(176, 136, 85, 0.12) 60%);
  padding: 0 2px;
}
.voice-result {
  font-family: var(--mincho);
  font-size: 12px;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  padding: var(--sp-2) var(--sp-3);
  background: var(--cream);
  border-left: 2px solid var(--brand-orange);
  margin-bottom: var(--sp-4);
  line-height: 1.7;
}
.voice-result-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 10.5px;
  color: var(--gold-deep);
  letter-spacing: 0.28em;
  font-weight: 500;
  margin-right: var(--sp-2);
  text-transform: uppercase;
}
.voice-name {
  font-family: var(--mincho);
  font-size: 13.5px;
  color: var(--ink-deep);
  font-weight: 500;
  letter-spacing: 0.06em;
  padding-top: var(--sp-3);
  border-top: 1px dashed var(--line-soft);
}
.voice-role {
  font-family: var(--mincho);
  font-size: 11px;
  color: var(--text-soft);
  margin-top: 3px;
  letter-spacing: 0.06em;
}

/* CEO inline credentials — minimal, no AI-feeling box */
.ceo-creds-inline {
  margin-top: var(--sp-5);
  padding: var(--sp-3) 0;
  border-top: 1px solid rgba(176, 136, 85, 0.32);
  border-bottom: 1px solid rgba(176, 136, 85, 0.32);
  font-family: var(--mincho);
  font-size: 11.5px;
  line-height: 1.85;
  letter-spacing: 0.06em;
  display: flex;
  align-items: baseline;
  gap: var(--sp-3);
  flex-wrap: wrap;
}
.ceo-creds-label-inline {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 10.5px;
  color: var(--gold-bright);
  letter-spacing: 0.28em;
  font-weight: 500;
  flex-shrink: 0;
  white-space: nowrap;
  text-transform: uppercase;
}
.ceo-creds-text {
  flex: 1;
  color: rgba(250, 247, 240, 0.85);
}

/* ============================================
   CEO Trust — bio paragraph
   ============================================ */
.ceo-trust-bio {
  font-family: var(--mincho);
  font-size: 14.5px;
  line-height: 2.05;
  color: var(--ink-mid);
  letter-spacing: 0.04em;
  margin: var(--sp-6) 0 var(--sp-5);
}
.ceo-trust-bio p {
  margin-bottom: var(--sp-3);
}
.ceo-trust-bio p:last-child {
  margin-bottom: 0;
}
.ceo-trust-bio strong {
  color: var(--ink-deep);
  font-weight: 500;
  background: linear-gradient(transparent 60%, rgba(176, 136, 85, 0.16) 60%);
  padding: 0 3px;
}

/* Inline credentials — minimal, no AI-feeling box */
.ceo-trust-creds-inline {
  margin: var(--sp-5) 0;
  padding: var(--sp-3) 0;
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  font-family: var(--mincho);
  font-size: 12px;
  line-height: 1.85;
  color: var(--text-soft);
  letter-spacing: 0.04em;
  display: flex;
  align-items: baseline;
  gap: var(--sp-3);
  flex-wrap: wrap;
}
.ceo-creds-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold-deep);
  letter-spacing: 0.28em;
  font-weight: 500;
  flex-shrink: 0;
  white-space: nowrap;
  text-transform: uppercase;
}
.ceo-creds-line {
  flex: 1;
  color: var(--ink-mid);
}

/* ============================================
   One-Stop Coverage — 8 service categories
   ============================================ */
.onestop-section {
  background: linear-gradient(180deg, var(--paper) 0%, var(--cream) 100%);
  padding: var(--sp-11) var(--sp-7);
  border-top: 1px solid rgba(176, 136, 85, 0.15);
  border-bottom: 1px solid rgba(176, 136, 85, 0.15);
}
.onestop-inner {
  max-width: 1240px;
  margin: 0 auto;
}
.onestop-head {
  text-align: center;
  margin-bottom: var(--sp-9);
}
.onestop-tag {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold-deep);
  letter-spacing: 0.32em;
  margin-bottom: var(--sp-3);
  font-weight: 500;
}
.onestop-title {
  font-family: var(--mincho-display);
  font-size: 34px;
  font-weight: 500;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  line-height: 1.55;
  margin-bottom: var(--sp-4);
}
.onestop-title em {
  font-style: normal;
  background: linear-gradient(transparent 60%, rgba(176, 136, 85, 0.18) 60%);
  padding: 0 6px;
}
.onestop-lead {
  font-family: var(--mincho);
  font-size: 14.5px;
  line-height: 1.95;
  color: var(--ink-mid);
  letter-spacing: 0.04em;
  max-width: 760px;
  margin: 0 auto;
}
.onestop-grid {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-9);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(176, 136, 85, 0.18);
  border: 1px solid rgba(176, 136, 85, 0.18);
}
.onestop-item {
  background: var(--white);
  padding: var(--sp-7) var(--sp-5);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
  text-align: center;
  transition: var(--t);
  position: relative;
}
.onestop-item:hover {
  background: linear-gradient(180deg, var(--white), rgba(255, 245, 230, 0.8));
}
.onestop-num {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold-deep);
  letter-spacing: 0.25em;
  font-weight: 500;
}
.onestop-jp {
  font-family: var(--mincho-display);
  font-size: 20px;
  color: var(--ink-deep);
  font-weight: 500;
  letter-spacing: 0.08em;
}
.onestop-en {
  font-family: var(--serif-en);
  font-size: 11px;
  color: var(--text-soft);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  font-weight: 500;
}
.onestop-grid {
  margin-bottom: 0;
}
@media (max-width: 768px) {
  .onestop-section { padding: var(--sp-9) var(--sp-5); }
  .onestop-title { font-size: 24px; }
  .onestop-grid { grid-template-columns: repeat(2, 1fr); }
  .onestop-jp { font-size: 17px; }
}

/* ============================================
   Voice page (お客様の声) — large block layout
   ============================================ */
.voice-list {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  gap: var(--sp-9);
}
.voice-block {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--sp-8);
  align-items: start;
  padding: var(--sp-7) 0;
  border-bottom: 1px solid var(--line-soft);
}
.voice-block:last-child { border-bottom: none; }
.voice-side { position: sticky; top: 100px; }
.voice-photo-lg {
  width: 100%;
  aspect-ratio: 4 / 3;
  margin-bottom: var(--sp-5);
  overflow: hidden;
  position: relative;
  background: var(--cream);
  box-shadow: 0 14px 40px rgba(10, 23, 41, 0.12);
}
.voice-photo-lg::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid rgba(176, 136, 85, 0.28);
  pointer-events: none;
}
.voice-photo-lg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  filter: contrast(1.03) saturate(1.05);
}
.voice-side .name {
  font-family: var(--mincho-display);
  font-size: 17px;
  font-weight: 500;
  color: var(--ink-deep);
  letter-spacing: 0.06em;
  margin-bottom: var(--sp-2);
}
.voice-side .role {
  font-family: var(--mincho);
  font-size: 12.5px;
  color: var(--text-soft);
  line-height: 1.7;
  margin-bottom: var(--sp-3);
  letter-spacing: 0.06em;
}
.voice-side .tag {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold-deep);
  letter-spacing: 0.3em;
  font-weight: 500;
  text-transform: uppercase;
}
.voice-main { padding-top: var(--sp-3); }
.voice-quote-lg {
  font-family: var(--mincho-display);
  font-size: 26px;
  font-weight: 500;
  line-height: 1.7;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-5);
  border-bottom: 2px solid var(--gold);
}
.voice-quote-lg em {
  font-style: normal;
  background: linear-gradient(transparent 60%, rgba(176, 136, 85, 0.18) 60%);
  padding: 0 4px;
}
.voice-content-text {
  font-family: var(--mincho);
  font-size: 15px;
  line-height: 2.0;
  color: var(--ink-mid);
  letter-spacing: 0.04em;
  margin-bottom: var(--sp-5);
}
.voice-content-text strong {
  color: var(--ink-deep);
  font-weight: 500;
  background: linear-gradient(transparent 60%, rgba(176, 136, 85, 0.16) 60%);
  padding: 0 3px;
}
.voice-meta-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin: 0 0 var(--sp-6);
  padding: var(--sp-4) var(--sp-5);
  background: var(--cream);
  border-left: 3px solid var(--gold);
}
.voice-meta-item {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: var(--sp-3);
  padding: 8px 0;
  border-bottom: 1px dashed rgba(176, 136, 85, 0.32);
}
.voice-meta-item:last-child { border-bottom: none; }
.voice-meta-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold-deep);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  font-style: normal;
  font-family: var(--mincho-display);
}
.voice-meta-val {
  font-family: var(--mincho);
  font-size: 13.5px;
  color: var(--ink-deep);
  line-height: 1.85;
  letter-spacing: 0.04em;
}
.voice-h {
  font-family: var(--mincho-display);
  font-size: 17px;
  font-weight: 500;
  color: var(--ink-deep);
  letter-spacing: 0.06em;
  line-height: 1.55;
  margin: var(--sp-6) 0 var(--sp-3);
  padding-left: 14px;
  border-left: 3px solid var(--brand-orange);
}
@media (max-width: 768px) {
  .voice-block {
    grid-template-columns: 1fr;
    gap: var(--sp-5);
    padding: var(--sp-6) 0;
  }
  .voice-side { position: static; }
  .voice-photo-lg { aspect-ratio: 16 / 10; max-width: 460px; }
  .voice-quote-lg { font-size: 21px; }
  .voice-content-text { font-size: 14px; line-height: 1.95; }
  .voice-meta-item { grid-template-columns: 1fr; gap: 4px; }
  .voice-meta-label { font-size: 10.5px; }
  .voice-meta-val { font-size: 13px; }
  .voice-h { font-size: 15.5px; }
}

/* ============================================
   CEO Section
   ============================================ */
.ceo-section { background: var(--ink-deep); color: var(--paper); padding: var(--sp-11) var(--sp-7); position: relative; overflow: hidden; }
.ceo-section::before {
  content: "";
  position: absolute;
  inset: var(--sp-7);
  border: 1px solid rgba(176, 136, 85, 0.15);
  pointer-events: none;
}
.ceo-section .section-head { color: var(--paper); }
.ceo-section .section-title { color: var(--paper); }
.ceo-section .section-title em { color: var(--gold-bright); border-bottom-color: var(--gold-bright); }
.ceo-section .chapter-mark { color: var(--gold-bright); }
.ceo-section .chapter-mark::before, .ceo-section .chapter-mark::after { background: var(--gold-bright); }

.ceo-grid {
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: var(--sp-9);
  max-width: 1240px;
  margin: 0 auto;
  align-items: center;
  position: relative;
}
.ceo-photo-wrap { position: relative; }
.ceo-photo {
  width: 420px;
  height: 540px;
  background-image: url('../images/brand/ceo-inoguchi.jpg');
  background-size: cover;
  background-position: center 20%;
  position: relative;
  z-index: 1;
}
.ceo-photo-frame {
  position: absolute;
  top: 22px;
  left: 22px;
  right: -22px;
  bottom: -22px;
  border: 1px solid var(--gold);
  z-index: 0;
}
.ceo-text { padding: var(--sp-3) 0; }
.ceo-role {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 12.5px;
  color: var(--gold-bright);
  letter-spacing: 0.32em;
  margin-bottom: var(--sp-4);
  font-weight: 500;
}
.ceo-name {
  font-family: var(--mincho-display);
  font-size: 42px;
  color: var(--paper);
  letter-spacing: 0.18em;
  margin-bottom: var(--sp-3);
  font-weight: 500;
}
.ceo-name-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 14px;
  color: var(--gold-light);
  letter-spacing: 0.28em;
  margin-bottom: var(--sp-6);
  font-weight: 500;
}
.ceo-quote {
  font-family: var(--mincho-display);
  font-size: clamp(22px, 2.6vw, 30px);
  line-height: 1.75;
  color: var(--gold-bright);
  font-weight: 500;
  letter-spacing: 0.04em;
  padding-left: var(--sp-6);
  border-left: 1px solid var(--gold);
  margin: var(--sp-6) 0;
}
.ceo-bio {
  font-family: var(--mincho);
  font-size: 14.5px;
  line-height: 2.3;
  color: rgba(250, 247, 240, 0.85);
  margin-bottom: var(--sp-5);
  letter-spacing: 0.05em;
}

/* CEO Stats — 実績数字を独立配置で目立たせる */
.ceo-stats {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--sp-5);
  margin: var(--sp-7) 0 var(--sp-6);
  padding: var(--sp-5) var(--sp-6);
  background: rgba(226, 199, 154, 0.05);
  border-top: 1px solid rgba(226, 199, 154, 0.32);
  border-bottom: 1px solid rgba(226, 199, 154, 0.32);
  flex-wrap: wrap;
}
.ceo-stat {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  min-width: 110px;
}
.ceo-stat-num {
  font-family: var(--serif-en);
  font-size: clamp(32px, 4vw, 44px);
  font-weight: 500;
  color: var(--gold-bright);
  line-height: 1;
  letter-spacing: 0.02em;
  font-style: italic;
}
.ceo-stat-unit {
  font-family: var(--mincho);
  font-size: 14px;
  color: var(--gold-light);
  margin-left: 4px;
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0.05em;
}
.ceo-stat-label {
  font-family: var(--mincho);
  font-size: 12px;
  color: rgba(250, 247, 240, 0.7);
  letter-spacing: 0.18em;
}
.ceo-stat-divider {
  width: 1px;
  height: 44px;
  background: rgba(226, 199, 154, 0.28);
}
@media (max-width: 720px) {
  .ceo-stats { gap: var(--sp-4); padding: var(--sp-4); }
  .ceo-stat { min-width: 90px; }
  .ceo-stat-divider { display: none; }
}

.ceo-creds-box {
  margin-top: var(--sp-6);
  padding-top: var(--sp-5);
  border-top: 1px solid rgba(176, 136, 85, 0.28);
}
.ceo-creds-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold-bright);
  letter-spacing: 0.35em;
  margin-bottom: var(--sp-4);
  font-weight: 500;
}
.ceo-creds-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-2) var(--sp-5);
  list-style: none;
  font-family: var(--mincho);
  font-size: 12.5px;
  color: rgba(250, 247, 240, 0.82);
  line-height: 1.95;
  letter-spacing: 0.04em;
}
.ceo-creds-list li {
  padding-left: var(--sp-4);
  position: relative;
}
.ceo-creds-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  width: 8px;
  height: 1px;
  background: var(--gold-bright);
}

/* ============================================
   Case Study (Before/After 相続対策)
   ============================================ */
.case-wrap { max-width: 1100px; margin: 0 auto; }
.case-row { display: grid; grid-template-columns: 1fr auto 1fr; gap: var(--sp-6); margin-bottom: var(--sp-7); align-items: stretch; }
.case-col { padding: var(--sp-8); background: var(--paper); border: 1px solid var(--line); position: relative; }
.case-col.after { background: var(--ink-deep); color: var(--paper); border-color: var(--gold); }
.case-label-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--text-soft);
  letter-spacing: 0.32em;
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--line);
  font-weight: 500;
}
.case-col.after .case-label-en { color: var(--gold-bright); border-bottom-color: rgba(176, 136, 85, 0.3); }
.case-stat-label { font-family: var(--mincho); font-size: 12px; color: var(--text-soft); letter-spacing: 0.18em; margin-bottom: var(--sp-3); }
.case-col.after .case-stat-label { color: rgba(250, 247, 240, 0.6); }
.case-stat {
  font-family: var(--serif-en);
  font-size: 64px;
  font-weight: 500;
  color: var(--text-mid);
  line-height: 1;
  letter-spacing: -0.04em;
  margin-bottom: var(--sp-5);
}
.case-col.after .case-stat { color: var(--gold-bright); }
.case-stat small { font-family: var(--mincho); font-size: 0.36em; font-weight: 400; letter-spacing: 0.15em; margin-left: 4px; }
.case-desc { font-family: var(--mincho); font-size: 13px; line-height: 2.1; color: var(--text); letter-spacing: 0.04em; }
.case-col.after .case-desc { color: rgba(250, 247, 240, 0.82); }
.case-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--serif-en);
  font-size: 26px;
  color: var(--gold);
  font-weight: 400;
}
.case-savings {
  background: var(--ink-deep);
  color: var(--paper);
  padding: var(--sp-7);
  text-align: center;
  border: 1px solid var(--gold);
  position: relative;
}
.case-savings::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(176, 136, 85, 0.35);
  pointer-events: none;
}
.case-savings-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold-bright);
  letter-spacing: 0.35em;
  margin-bottom: var(--sp-3);
  font-weight: 500;
}
.case-savings-value {
  font-family: var(--serif-en);
  font-size: 64px;
  color: var(--gold-bright);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.03em;
  margin-bottom: var(--sp-5);
}
.case-savings-value small {
  font-family: var(--mincho);
  font-size: 0.32em;
  font-weight: 400;
  letter-spacing: 0.15em;
  margin-left: 4px;
  color: var(--gold-light);
}

/* ============================================
   Blog Cards (SEO流入受け皿)
   ============================================ */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-7);
  max-width: 1240px;
  margin: 0 auto;
}
.blog-card {
  display: flex;
  flex-direction: column;
  color: inherit;
  text-decoration: none;
  background: #fff;
  border: 1px solid rgba(176, 136, 85, 0.2);
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 6px 18px rgba(14, 27, 46, 0.05);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
.section-dark .blog-card { background: rgba(255, 255, 255, 0.04); border-color: rgba(226, 199, 154, 0.2); box-shadow: none; }
.blog-card:hover { transform: translateY(-6px); color: inherit; box-shadow: 0 26px 54px rgba(14, 27, 46, 0.16); border-color: rgba(226, 199, 154, 0.5); }
.section-dark .blog-card:hover { box-shadow: 0 26px 54px rgba(0, 0, 0, 0.3); }
.blog-card-image {
  aspect-ratio: 16 / 10;
  background-size: cover !important;
  background-position: center !important;
  margin-bottom: 0;
  position: relative;
  transition: transform 0.6s ease;
}
.blog-card:hover .blog-card-image { transform: scale(1.06); }
.img-hakata { background-image: url('https://images.unsplash.com/photo-1624253321171-1be53e12f5f4?w=900&q=88&auto=format&fit=crop'); }
.img-tenjin { background-image: url('https://images.unsplash.com/photo-1554188248-986adbb73be4?w=900&q=88&auto=format&fit=crop'); }
.img-tower { background-image: url('https://images.unsplash.com/photo-1553913861-c0fddf2619ee?w=900&q=88&auto=format&fit=crop'); }
.img-office { background-image: url('https://images.unsplash.com/photo-1497366216548-37526070297c?w=900&q=88&auto=format&fit=crop'); }
.img-bank { background-image: url('https://images.unsplash.com/photo-1450101499163-c8848c66ca85?w=900&q=88&auto=format&fit=crop'); }
.img-night { background-image: url('https://images.unsplash.com/photo-1519500528352-2d1460418d41?w=900&q=88&auto=format&fit=crop'); }
.blog-cat {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.3em;
  margin: 26px 28px 12px;
  font-weight: 500;
}
.blog-title {
  font-family: var(--mincho-display);
  font-size: 19px;
  font-weight: 500;
  color: var(--ink-deep);
  line-height: 1.6;
  margin: 0 28px 14px;
  letter-spacing: 0.02em;
}
.section-dark .blog-title { color: var(--paper); }
.blog-excerpt {
  font-family: var(--mincho);
  font-size: 13px;
  line-height: 2;
  color: var(--text-mid);
  margin: 0 28px 16px;
  letter-spacing: 0.04em;
  flex-grow: 1;
}
.section-dark .blog-excerpt { color: rgba(250, 247, 240, 0.7); }
.blog-meta {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--text-soft);
  letter-spacing: 0.2em;
  margin: 0 28px 26px;
  padding-top: var(--sp-3);
  border-top: 1px solid var(--line-soft);
  font-weight: 500;
}
.section-dark .blog-meta { color: var(--gold-light); border-top-color: rgba(176, 136, 85, 0.2); }

/* ============================================
   Pillars (4 categories)
   ============================================ */
.pillars-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-5);
  max-width: 1240px;
  margin: 0 auto;
}
.pillar-card {
  display: block;
  color: inherit;
  text-decoration: none;
  background: var(--white);
  padding: var(--sp-9) var(--sp-6);
  border: 1px solid var(--line-soft);
  text-align: center;
  transition: var(--t);
}
.pillar-card:hover { transform: translateY(-6px); border-color: var(--gold); box-shadow: var(--shadow-md); color: inherit; }
.pillar-num {
  font-family: var(--mincho-display);
  font-size: 52px;
  color: var(--gold);
  line-height: 1;
  margin-bottom: var(--sp-5);
  font-weight: 400;
}
.pillar-title {
  font-family: var(--mincho-display);
  font-size: 21px;
  color: var(--ink-deep);
  font-weight: 500;
  margin-bottom: var(--sp-3);
  letter-spacing: 0.04em;
}
.pillar-count {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11.5px;
  color: var(--gold);
  letter-spacing: 0.3em;
  margin-bottom: var(--sp-5);
  font-weight: 500;
}
.pillar-link {
  font-family: var(--mincho);
  font-size: 12.5px;
  color: var(--ink-deep);
  border-bottom: 1px solid var(--ink-deep);
  padding-bottom: 3px;
  letter-spacing: 0.1em;
}

/* ============================================
   Concerns (こんな方へ)
   ============================================ */
.concerns-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  max-width: 1240px;
  margin: 0 auto;
  border: 1px solid var(--line);
}
.concern-item {
  padding: var(--sp-7) var(--sp-6);
  background: var(--white);
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  transition: var(--t);
}
.concern-item:nth-child(3n) { border-right: none; }
.concern-item:nth-last-child(-n+3) { border-bottom: none; }
.concern-item:hover { background: var(--paper-warm); }
.concern-num-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold);
  letter-spacing: 0.3em;
  margin-bottom: var(--sp-3);
  font-weight: 500;
}
.concern-title {
  font-family: var(--mincho-display);
  font-size: 19px;
  font-weight: 500;
  color: var(--ink-deep);
  line-height: 1.6;
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--line-soft);
  letter-spacing: 0.02em;
}
.concern-body {
  font-family: var(--mincho);
  font-size: 13.5px;
  line-height: 2.1;
  color: var(--text-mid);
  letter-spacing: 0.04em;
}

/* ============================================
   3-tier CTA Section
   ============================================ */
.cta-tier {
  background: var(--paper-warm);
  padding: var(--sp-11) var(--sp-7);
}
.cta-tier-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
  max-width: 1140px;
  margin: 0 auto;
}
.cta-tier-card {
  background: var(--white);
  padding: var(--sp-8);
  border: 1px solid var(--line);
  text-align: center;
  display: block;
  color: inherit;
  text-decoration: none;
  transition: var(--t);
  position: relative;
}
.cta-tier-card:hover { transform: translateY(-5px); border-color: var(--gold); box-shadow: var(--shadow-md); color: inherit; }
.cta-tier-step {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold);
  letter-spacing: 0.4em;
  margin-bottom: var(--sp-5);
  font-weight: 500;
}
.cta-tier-title {
  font-family: var(--mincho-display);
  font-size: 24px;
  color: var(--ink-deep);
  font-weight: 500;
  margin-bottom: var(--sp-4);
  letter-spacing: 0.04em;
}
.cta-tier-desc {
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--text-mid);
  line-height: 2.1;
  margin-bottom: var(--sp-6);
  letter-spacing: 0.04em;
  min-height: 84px;
}
.cta-tier-btn {
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--ink-deep);
  border-bottom: 1px solid var(--ink-deep);
  padding-bottom: 3px;
  letter-spacing: 0.12em;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: var(--t);
}
.cta-tier-card:hover .cta-tier-btn { color: var(--gold-deep); border-bottom-color: var(--gold-deep); gap: 14px; }

/* ============================================
   Final CTA
   ============================================ */
.final-cta {
  position: relative;
  padding: var(--sp-12) var(--sp-7);
  color: var(--paper);
  text-align: center;
  overflow: hidden;
  background: var(--ink-deep);
}
.final-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(10, 23, 41, 0.92), rgba(10, 23, 41, 0.95)),
    url('https://images.unsplash.com/photo-1519500528352-2d1460418d41?w=2400&q=88&auto=format&fit=crop');
  background-size: cover;
  background-position: center;
}
.final-cta::after {
  content: "";
  position: absolute;
  inset: var(--sp-7);
  border: 1px solid rgba(176, 136, 85, 0.22);
  pointer-events: none;
}
.final-cta-inner { position: relative; z-index: 1; }
.final-cta-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 13px;
  color: var(--gold-bright);
  letter-spacing: 0.42em;
  margin-bottom: var(--sp-5);
  display: block;
  font-weight: 500;
}
.final-cta h2 {
  font-family: var(--mincho-display);
  font-size: clamp(34px, 4.5vw, 58px);
  color: var(--paper);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-7);
}
.final-cta h2 em { font-style: normal; color: var(--gold-bright); }
.final-cta p {
  font-family: var(--mincho);
  font-size: 15.5px;
  color: rgba(250, 247, 240, 0.82);
  line-height: 2.3;
  max-width: 640px;
  margin: 0 auto var(--sp-9);
  letter-spacing: 0.06em;
}
.final-cta-buttons {
  display: flex;
  gap: var(--sp-4);
  justify-content: center;
  flex-wrap: wrap;
}
.final-cta-phone {
  font-family: var(--mincho);
  font-size: 13px;
  color: rgba(250, 247, 240, 0.6);
  letter-spacing: 0.18em;
  margin-top: var(--sp-7);
  padding-top: var(--sp-6);
  border-top: 1px solid rgba(176, 136, 85, 0.22);
  max-width: 420px;
  margin-left: auto;
  margin-right: auto;
}
.final-cta-phone strong {
  font-family: var(--serif-en);
  font-size: 22px;
  color: var(--gold-bright);
  letter-spacing: 0.08em;
  display: block;
  margin-top: var(--sp-2);
  font-weight: 500;
}

/* ============================================
   Footer
   ============================================ */
.site-footer {
  background: var(--ink-deep);
  color: var(--paper);
  padding: var(--sp-10) var(--sp-7) var(--sp-6);
  border-top: 1px solid rgba(176, 136, 85, 0.32);
}
.footer-inner {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
  gap: var(--sp-7);
  padding-bottom: var(--sp-8);
  border-bottom: 1px solid rgba(176, 136, 85, 0.18);
}
.footer-logo-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold-bright);
  letter-spacing: 0.32em;
  margin-bottom: var(--sp-3);
  font-weight: 500;
}
.footer-logo-jp {
  font-family: var(--mincho-display);
  font-size: 21px;
  color: var(--paper);
  letter-spacing: 0.1em;
  margin-bottom: var(--sp-5);
  font-weight: 500;
}
.footer-logo-img {
  display: block;
  height: 60px;
  width: auto;
  max-width: 300px;
  object-fit: contain;
  margin-bottom: var(--sp-5);
  filter: brightness(0) invert(1);
  opacity: 0.95;
  image-rendering: -webkit-optimize-contrast;
  -webkit-user-drag: none;
}
.footer-addr {
  font-family: var(--mincho);
  font-size: 12px;
  color: rgba(250, 247, 240, 0.7);
  line-height: 2.1;
  letter-spacing: 0.04em;
}
.footer-phone {
  font-family: var(--serif-en);
  font-size: 18px;
  color: var(--gold-bright);
  letter-spacing: 0.08em;
  margin-top: var(--sp-3);
  font-weight: 500;
}
.footer-col h4 {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold-bright);
  letter-spacing: 0.35em;
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid rgba(176, 136, 85, 0.25);
  font-weight: 500;
}
.footer-col a {
  font-family: var(--mincho);
  display: block;
  font-size: 13px;
  color: rgba(250, 247, 240, 0.78);
  padding: var(--sp-2) 0;
  letter-spacing: 0.06em;
  transition: var(--t-fast);
}
.footer-col a:hover { color: var(--gold-bright); padding-left: var(--sp-2); }
.footer-bottom {
  max-width: 1240px;
  margin: var(--sp-5) auto 0;
  display: flex;
  justify-content: space-between;
  font-family: var(--mincho);
  font-size: 10.5px;
  color: rgba(250, 247, 240, 0.5);
  letter-spacing: 0.1em;
  flex-wrap: wrap;
  gap: var(--sp-3);
}

/* ============================================
   Floating LINE
   ============================================ */
.line-fixed {
  position: fixed;
  bottom: var(--sp-6);
  right: var(--sp-6);
  background: var(--line-green);
  color: var(--white);
  padding: 16px 24px;
  box-shadow: 0 12px 36px rgba(6, 199, 85, 0.32);
  z-index: 80;
  font-family: var(--mincho);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.12em;
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  transition: var(--t);
}
.line-fixed::before {
  content: "●";
  color: var(--white);
  font-size: 8px;
}
.line-fixed:hover {
  transform: translateY(-3px);
  color: var(--white);
  box-shadow: 0 18px 48px rgba(6, 199, 85, 0.42);
}

/* ============================================
   Page Hero (Inner pages)
   ============================================ */
.page-hero {
  position: relative;
  padding: var(--sp-10) var(--sp-7) var(--sp-9);
  background: var(--ink-deep);
  color: var(--paper);
  overflow: hidden;
}
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(110deg, rgba(10, 23, 41, 0.93), rgba(17, 37, 69, 0.78)),
    url('https://images.unsplash.com/photo-1554188248-986adbb73be4?w=2200&q=86&auto=format&fit=crop');
  background-size: cover;
  background-position: center;
}
.page-hero-inner { position: relative; z-index: 1; max-width: 1100px; margin: 0 auto; }
.page-hero-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 13px;
  color: var(--gold-bright);
  letter-spacing: 0.36em;
  margin-bottom: var(--sp-5);
  font-weight: 500;
}
.page-hero h1 {
  font-family: var(--mincho-display);
  font-size: clamp(32px, 4.5vw, 54px);
  font-weight: 500;
  line-height: 1.45;
  color: var(--paper);
  letter-spacing: 0.04em;
  margin-bottom: var(--sp-6);
}
.page-hero h1 em { font-style: normal; color: var(--gold-bright); }
.page-hero-lead {
  font-family: var(--mincho);
  font-size: 15px;
  line-height: 2.3;
  color: rgba(250, 247, 240, 0.82);
  max-width: 680px;
  letter-spacing: 0.06em;
}

/* Breadcrumb */
.breadcrumb {
  background: var(--paper);
  padding: var(--sp-4) var(--sp-7);
  font-family: var(--mincho);
  font-size: 12px;
  color: var(--text-soft);
  border-bottom: 1px solid var(--line-soft);
  letter-spacing: 0.08em;
}
.breadcrumb .container { padding: 0; max-width: 1240px; }
.breadcrumb a { color: var(--gold-deep); }
.breadcrumb a:hover { color: var(--gold); }

/* ============================================
   Form
   ============================================ */
.form-box {
  background: var(--white);
  padding: var(--sp-9);
  border: 1px solid var(--line);
  position: relative;
  max-width: 880px;
  margin: 0 auto;
}
.form-box::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}
.form-box h2 {
  font-family: var(--mincho-display);
  font-size: 26px;
  color: var(--ink-deep);
  font-weight: 500;
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--gold);
  margin-bottom: var(--sp-7);
  letter-spacing: 0.04em;
}
.field { margin-bottom: var(--sp-6); }
.field-label {
  display: block;
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--ink-deep);
  font-weight: 500;
  margin-bottom: var(--sp-3);
  letter-spacing: 0.1em;
}
.field-label .req { background: var(--accent-vermillion); color: var(--paper); font-size: 10px; padding: 3px 8px; margin-left: var(--sp-2); letter-spacing: 0.1em; }
.field-label .opt { background: var(--line-soft); color: var(--text-soft); font-size: 10px; padding: 3px 8px; margin-left: var(--sp-2); letter-spacing: 0.1em; }
.field-hint { font-size: 11.5px; color: var(--text-soft); margin-top: 5px; letter-spacing: 0.04em; }
.field input, .field textarea, .field select {
  width: 100%;
  padding: 15px 18px;
  border: 1px solid var(--line);
  font-family: var(--mincho);
  font-size: 14px;
  background: var(--white);
  color: var(--ink-deep);
  letter-spacing: 0.03em;
  transition: var(--t-fast);
}
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(176, 136, 85, 0.14);
}
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
.field-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--sp-4); }
.radio-group { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-2); }
.radio-group.single { grid-template-columns: repeat(4, 1fr); }
.radio-item { border: 1px solid var(--line); padding: 14px 18px; cursor: pointer; font-family: var(--mincho); font-size: 13px; transition: var(--t-fast); background: var(--white); display: flex; align-items: center; gap: var(--sp-2); letter-spacing: 0.04em; }
.radio-item:hover { border-color: var(--gold); background: var(--paper); }
.privacy-note { background: var(--paper); padding: var(--sp-5); font-family: var(--mincho); font-size: 11.5px; color: var(--text); line-height: 2; margin-bottom: var(--sp-6); border-left: 2px solid var(--gold); letter-spacing: 0.04em; }
.submit-block { text-align: center; padding-top: var(--sp-6); border-top: 1px solid var(--line-soft); }
.submit-btn {
  background: var(--ink-deep);
  color: var(--paper);
  padding: 22px 64px;
  font-family: var(--mincho);
  font-size: 15px;
  font-weight: 500;
  border: 1px solid var(--gold);
  cursor: pointer;
  transition: var(--t);
  letter-spacing: 0.32em;
  position: relative;
}
.submit-btn:hover { background: var(--ink); transform: translateY(-2px); box-shadow: 0 20px 48px rgba(10, 23, 41, 0.4); }

/* ============================================
   Responsive
   ============================================ */
@media (max-width: 1100px) {
  .header-inner { grid-template-columns: auto auto; gap: var(--sp-4); }
  .global-nav { display: none; }
  .hero-inner { grid-template-columns: 1fr; }
  .hero-stats { max-width: 480px; }
  .strengths-grid { grid-template-columns: 1fr; gap: var(--sp-5); }
  .big-numbers-row { grid-template-columns: repeat(2, 1fr); }
  .big-number { border-right: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); }
  .big-number:nth-child(2n) { border-right: none; }
  .big-number:nth-last-child(-n+2) { border-bottom: none; }
  .fukuoka-grid { grid-template-columns: 1fr; }
  .fukuoka-image { min-height: 360px; }
  .voices-grid { grid-template-columns: 1fr; }
  .ceo-grid { grid-template-columns: 1fr; gap: var(--sp-7); }
  .ceo-photo { width: 100%; max-width: 420px; margin: 0 auto; }
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .pillars-grid { grid-template-columns: repeat(2, 1fr); }
  .concerns-grid { grid-template-columns: repeat(2, 1fr); }
  .concern-item { border-right: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); }
  .concern-item:nth-child(3n) { border-right: 1px solid var(--line-soft); }
  .concern-item:nth-last-child(-n+3) { border-bottom: 1px solid var(--line-soft); }
  .concern-item:nth-child(2n) { border-right: none; }
  .cta-tier-grid { grid-template-columns: 1fr; }
  .case-row { grid-template-columns: 1fr; }
  .case-arrow { transform: rotate(90deg); padding: var(--sp-3); font-size: 32px; }
  .footer-inner { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .section { padding: var(--sp-9) var(--sp-4); }
  .hero { padding: var(--sp-8) var(--sp-4); min-height: auto; }
  .hero-h1 { font-size: 36px; }
  .header-phone { display: none; }
  .big-numbers-row, .blog-grid, .pillars-grid, .concerns-grid, .fukuoka-stat-grid { grid-template-columns: 1fr; }
  .ceo-creds-list { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr; }
  .field-row, .field-row-3, .radio-group, .radio-group.single { grid-template-columns: 1fr; }
  .hero-cta-row { flex-direction: column; align-items: stretch; }
  .hero-cta-row .btn { justify-content: center; }
  .line-fixed { bottom: var(--sp-3); right: var(--sp-3); padding: 12px 18px; font-size: 12px; }
}

/* ============================================
   ADDITIONAL SECTIONS — Conversion Booster
   ============================================ */

/* === Persona Routing (どの段階の方ですか) === */
.persona-routing { background: var(--paper); padding: var(--sp-11) var(--sp-7); }
.persona-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); max-width: 1240px; margin: 0 auto; }
.persona-card {
  background: var(--white);
  padding: var(--sp-8);
  border: 1px solid var(--line);
  position: relative;
  transition: var(--t);
  display: flex;
  flex-direction: column;
}
.persona-card:hover { border-color: var(--gold); transform: translateY(-5px); box-shadow: var(--shadow-md); }
.persona-stage {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.4em;
  margin-bottom: var(--sp-3);
  font-weight: 500;
}
.persona-stage-num {
  font-family: var(--mincho-display);
  font-size: 56px;
  color: var(--ink-deep);
  line-height: 1;
  font-weight: 400;
  margin-bottom: var(--sp-5);
  letter-spacing: 0.05em;
}
.persona-title {
  font-family: var(--mincho-display);
  font-size: 21px;
  color: var(--ink-deep);
  font-weight: 500;
  line-height: 1.6;
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--line-soft);
  letter-spacing: 0.02em;
}
.persona-title em { font-style: normal; color: var(--gold-deep); }
.persona-checklist {
  list-style: none;
  margin-bottom: var(--sp-6);
  flex: 1;
}
.persona-checklist li {
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--text);
  line-height: 2;
  padding-left: var(--sp-5);
  position: relative;
  letter-spacing: 0.04em;
}
.persona-checklist li::before {
  content: "—";
  position: absolute;
  left: 0;
  color: var(--gold);
  font-weight: 500;
}
.persona-recommend {
  background: var(--paper-warm);
  padding: var(--sp-4);
  margin-bottom: var(--sp-5);
  border-left: 2px solid var(--gold);
}
.persona-recommend-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 10px;
  color: var(--gold-deep);
  letter-spacing: 0.32em;
  font-weight: 500;
  margin-bottom: 4px;
}
.persona-recommend-text {
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--ink-deep);
  font-weight: 500;
  letter-spacing: 0.04em;
}
.persona-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--ink-deep);
  border-bottom: 1px solid var(--ink-deep);
  padding-bottom: 3px;
  letter-spacing: 0.1em;
  align-self: flex-start;
  transition: var(--t-fast);
}
.persona-card:hover .persona-cta { color: var(--gold-deep); border-bottom-color: var(--gold-deep); gap: 14px; }

/* === Comparison Table (他社との違い) === */
.compare-section { background: var(--cream); padding: var(--sp-11) var(--sp-7); }
.compare-table-wrap { max-width: 1100px; margin: 0 auto; overflow-x: auto; }
.compare-tbl {
  width: 100%;
  border-collapse: collapse;
  background: var(--white);
  border: 1px solid var(--line);
  font-family: var(--mincho);
}
.compare-tbl thead th {
  padding: var(--sp-6) var(--sp-4);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-align: center;
  border-right: 1px solid var(--line-soft);
}
.compare-tbl thead th:first-child {
  background: var(--paper);
  color: var(--text);
  text-align: left;
  width: 28%;
}
.compare-tbl thead th.hilite {
  background: var(--ink-deep);
  color: var(--paper);
  border-color: var(--gold);
  position: relative;
}
.compare-tbl thead th.hilite::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--gold);
}
.compare-tbl thead th.hilite small {
  display: block;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 10px;
  color: var(--gold-bright);
  letter-spacing: 0.32em;
  margin-bottom: 3px;
  font-weight: 500;
}
.compare-tbl thead th.muted {
  background: var(--paper);
  color: var(--text-soft);
}
.compare-tbl thead th.muted small {
  display: block;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 10px;
  letter-spacing: 0.25em;
  margin-bottom: 3px;
  font-weight: 500;
}
.compare-tbl tbody th {
  padding: var(--sp-4) var(--sp-5);
  background: var(--paper);
  text-align: left;
  font-size: 13px;
  color: var(--ink-deep);
  font-weight: 500;
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  letter-spacing: 0.04em;
}
.compare-tbl tbody td {
  padding: var(--sp-4) var(--sp-4);
  text-align: center;
  font-size: 13px;
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  letter-spacing: 0.04em;
  line-height: 1.7;
}
.compare-tbl tbody td.hilite {
  background: rgba(176, 136, 85, 0.06);
  color: var(--ink-deep);
  font-weight: 500;
}
.compare-tbl tbody td.hilite-strong {
  background: rgba(176, 136, 85, 0.12);
  color: var(--ink-deep);
  font-weight: 700;
}
.compare-tbl tbody td.muted { color: var(--text-soft); }
.compare-tbl tbody tr:last-child th, .compare-tbl tbody tr:last-child td { border-bottom: none; }
.compare-mark { font-family: var(--serif-en); font-size: 22px; font-weight: 500; line-height: 1; }
.compare-mark.yes { color: var(--gold-deep); }
.compare-mark.no { color: var(--text-light); }

/* === Material Request CTA (Banner) === */
.material-banner {
  background: var(--ink-deep);
  color: var(--paper);
  padding: var(--sp-9) var(--sp-7);
  position: relative;
  overflow: hidden;
}
.material-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(110deg, rgba(10,23,41,0.92), rgba(17,37,69,0.85)),
    url('https://images.unsplash.com/photo-1450101499163-c8848c66ca85?w=1800&q=85&auto=format&fit=crop');
  background-size: cover;
  background-position: center;
}
.material-banner-inner {
  position: relative;
  z-index: 1;
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--sp-9);
  align-items: center;
}
.material-banner-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 13px;
  color: var(--gold-bright);
  letter-spacing: 0.4em;
  margin-bottom: var(--sp-4);
  font-weight: 500;
}
.material-banner h2 {
  font-family: var(--mincho-display);
  font-size: clamp(28px, 3.5vw, 42px);
  color: var(--paper);
  font-weight: 500;
  line-height: 1.5;
  margin-bottom: var(--sp-5);
  letter-spacing: 0.04em;
}
.material-banner h2 em { font-style: normal; color: var(--gold-bright); }
.material-banner p {
  font-family: var(--mincho);
  font-size: 14.5px;
  color: rgba(250, 247, 240, 0.85);
  line-height: 2.1;
  margin-bottom: var(--sp-6);
  letter-spacing: 0.05em;
}
.material-banner-features {
  list-style: none;
  margin-bottom: var(--sp-7);
}
.material-banner-features li {
  font-family: var(--mincho);
  font-size: 13.5px;
  color: rgba(250, 247, 240, 0.92);
  line-height: 2.1;
  padding-left: var(--sp-5);
  position: relative;
  letter-spacing: 0.04em;
}
.material-banner-features li::before {
  content: "◆";
  position: absolute;
  left: 0;
  color: var(--gold-bright);
  font-size: 9px;
  top: 8px;
}
.material-mockup {
  background: linear-gradient(135deg, var(--gold-light), var(--gold-deep));
  padding: var(--sp-8);
  position: relative;
  aspect-ratio: 3/4;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border: 1px solid var(--gold-bright);
  box-shadow: 0 30px 80px rgba(0,0,0,0.4);
  transform: rotate(-2deg);
}
.material-mockup::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid rgba(248, 244, 234, 0.3);
}
.material-mockup-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: rgba(248, 244, 234, 0.7);
  letter-spacing: 0.32em;
  font-weight: 500;
  position: relative;
  z-index: 1;
}
.material-mockup-title {
  font-family: var(--mincho-display);
  font-size: 24px;
  color: var(--paper);
  line-height: 1.5;
  letter-spacing: 0.06em;
  font-weight: 500;
  position: relative;
  z-index: 1;
}
.material-mockup-title em { font-style: normal; display: block; font-size: 14px; color: var(--gold-bright); margin-top: var(--sp-3); letter-spacing: 0.25em; }
.material-mockup-meta {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: rgba(248, 244, 234, 0.7);
  letter-spacing: 0.25em;
  font-weight: 500;
  padding-top: var(--sp-4);
  border-top: 1px solid rgba(248, 244, 234, 0.25);
  position: relative;
  z-index: 1;
}

/* === Authority Logos (権威付け) === */
.authority-section { background: var(--paper); padding: var(--sp-9) var(--sp-7); border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); }
.authority-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.5em;
  text-align: center;
  margin-bottom: var(--sp-6);
  font-weight: 500;
}
.authority-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  max-width: 1100px;
  margin: 0 auto;
  align-items: center;
}
.authority-item {
  text-align: center;
  padding: var(--sp-4);
  border-right: 1px solid var(--line-soft);
}
.authority-item:last-child { border-right: none; }
.authority-item-name {
  font-family: var(--mincho);
  font-size: 12px;
  color: var(--ink-deep);
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.6;
}
.authority-item-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 10px;
  color: var(--gold);
  letter-spacing: 0.25em;
  margin-top: 4px;
  font-weight: 500;
}

/* === Diagnosis (診断ツール) === */
.diagnosis-section { background: var(--paper-warm); padding: var(--sp-11) var(--sp-7); }
.diagnosis-box {
  max-width: 880px;
  margin: 0 auto;
  background: var(--white);
  padding: var(--sp-9);
  border: 1px solid var(--line);
  position: relative;
}
.diagnosis-box::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}
.diag-step {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.4em;
  text-align: center;
  margin-bottom: var(--sp-3);
  font-weight: 500;
}
.diag-question {
  font-family: var(--mincho-display);
  font-size: 26px;
  color: var(--ink-deep);
  text-align: center;
  font-weight: 500;
  line-height: 1.6;
  margin-bottom: var(--sp-7);
  letter-spacing: 0.04em;
}
.diag-options { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.diag-option {
  padding: var(--sp-5) var(--sp-6);
  background: var(--cream);
  border: 1px solid var(--line);
  cursor: pointer;
  font-family: var(--mincho);
  font-size: 14px;
  color: var(--ink-deep);
  text-align: left;
  letter-spacing: 0.04em;
  transition: var(--t);
  line-height: 1.7;
}
.diag-option:hover { border-color: var(--gold); background: var(--paper-warm); transform: translateY(-2px); }
.diag-option .label {
  display: block;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.25em;
  margin-bottom: 4px;
  font-weight: 500;
}

/* === Loose case study items (失敗事例) === */
.failure-list { max-width: 1000px; margin: 0 auto; }
.failure-item {
  background: var(--white);
  padding: var(--sp-7) var(--sp-8);
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent-vermillion);
  margin-bottom: var(--sp-4);
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: var(--sp-6);
  align-items: start;
}
.failure-num {
  font-family: var(--mincho-display);
  font-size: 36px;
  color: var(--accent-vermillion);
  line-height: 1;
  font-weight: 400;
  letter-spacing: 0.05em;
}
.failure-title {
  font-family: var(--mincho-display);
  font-size: 18px;
  color: var(--ink-deep);
  font-weight: 500;
  margin-bottom: var(--sp-3);
  line-height: 1.55;
  letter-spacing: 0.02em;
}
.failure-body {
  font-family: var(--mincho);
  font-size: 13.5px;
  color: var(--text);
  line-height: 2.1;
  letter-spacing: 0.04em;
}
.failure-counter {
  margin-top: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px dashed var(--line);
  font-family: var(--mincho);
  font-size: 12.5px;
  color: var(--gold-deep);
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.95;
}
.failure-counter em { font-style: normal; color: var(--ink-deep); }

/* === Long-form case study === */
.case-detail-wrap { max-width: 920px; margin: 0 auto; }
.case-detail-block {
  background: var(--white);
  padding: var(--sp-8);
  border: 1px solid var(--line-soft);
  margin-bottom: var(--sp-5);
}
.case-detail-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.4em;
  margin-bottom: var(--sp-3);
  font-weight: 500;
}
.case-detail-h {
  font-family: var(--mincho-display);
  font-size: 24px;
  color: var(--ink-deep);
  font-weight: 500;
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--gold);
  letter-spacing: 0.03em;
}
.case-detail-p {
  font-family: var(--mincho);
  font-size: 14.5px;
  line-height: 2.3;
  color: var(--text);
  margin-bottom: var(--sp-4);
  letter-spacing: 0.04em;
}
.case-detail-p strong {
  color: var(--ink-deep);
  font-weight: 500;
  background: linear-gradient(transparent 65%, rgba(176,136,85,0.22) 65%);
  padding: 0 2px;
}

/* === Sticky bottom CTA (商談へ呼ぶ最後の一押し) === */
.sticky-cta {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(10, 23, 41, 0.96);
  backdrop-filter: blur(14px);
  color: var(--paper);
  padding: var(--sp-3) var(--sp-7);
  z-index: 70;
  border-top: 1px solid var(--gold);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-4);
}
.sticky-cta-text {
  font-family: var(--mincho);
  font-size: 13.5px;
  letter-spacing: 0.06em;
}
.sticky-cta-text strong { color: var(--gold-bright); font-weight: 500; }
.sticky-cta-text small { display: block; font-family: var(--serif-en); font-style: italic; font-size: 10px; color: var(--gold-light); letter-spacing: 0.3em; margin-top: 2px; font-weight: 500; }
.sticky-cta-btns { display: flex; gap: var(--sp-2); flex-wrap: nowrap; }
.sticky-cta-btn {
  font-family: var(--mincho);
  padding: 10px 20px;
  font-size: 12.5px;
  letter-spacing: 0.12em;
  border: 1px solid var(--gold);
  color: var(--paper);
  white-space: nowrap;
  transition: var(--t-fast);
}
.sticky-cta-btn:hover { background: var(--gold); color: var(--ink-deep); }
.sticky-cta-btn.primary { background: var(--gold); color: var(--ink-deep); font-weight: 500; }
.sticky-cta-btn.primary:hover { background: var(--gold-bright); }

/* === Responsive for new sections === */
@media (max-width: 1024px) {
  .persona-grid { grid-template-columns: 1fr; }
  .material-banner-inner { grid-template-columns: 1fr; }
  .material-mockup { transform: none; max-width: 320px; margin: 0 auto; }
  .compare-tbl { font-size: 11px; }
  .compare-tbl thead th, .compare-tbl tbody th, .compare-tbl tbody td { padding: var(--sp-3); font-size: 11.5px; }
  .authority-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-4); }
  .authority-item { border: none; padding: var(--sp-3); }
  .diag-options { grid-template-columns: 1fr; }
  .sticky-cta { padding: var(--sp-2) var(--sp-3); }
  .sticky-cta-text { font-size: 11.5px; }
  .sticky-cta-btn { padding: 8px 14px; font-size: 11px; }
}
@media (max-width: 640px) {
  .sticky-cta { flex-direction: column; gap: var(--sp-2); padding: var(--sp-3); }
  .sticky-cta-text { text-align: center; }
  .failure-item { grid-template-columns: 1fr; gap: var(--sp-3); }
}

/* ============================================================
   DESIGN UPGRADE LAYER v2
   インパクト・コントラスト・階層を強化(構造は触らず見た目のみ)
   ============================================================ */

/* === タイポグラフィの圧 === */
.hero { min-height: 92vh; }
.hero::before {
  background-image:
    linear-gradient(105deg, rgba(7,16,30,0.96) 22%, rgba(11,26,52,0.84) 58%, rgba(20,42,80,0.42) 100%),
    radial-gradient(ellipse at 80% 20%, rgba(176,136,85,0.18), transparent 55%),
    url('https://images.unsplash.com/photo-1590559899731-a382839e5549?w=2400&q=88&auto=format&fit=crop');
  background-size: cover, cover, cover;
  background-position: center 35%;
}
.hero::after {
  inset: var(--sp-5);
  border: 1px solid rgba(176, 136, 85, 0.32);
  box-shadow: inset 0 0 120px rgba(0,0,0,0.45);
}
.hero-h1 {
  font-size: clamp(44px, 6.4vw, 96px);
  line-height: 1.22;
  letter-spacing: 0.015em;
  text-shadow: 0 6px 30px rgba(0,0,0,0.4);
}
.hero-h1 em {
  background: linear-gradient(135deg, var(--gold-bright) 0%, #f3dca8 50%, var(--gold-light) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.hero-sub { font-size: 16.5px; line-height: 2.3; }
.hero-stats {
  background: linear-gradient(165deg, rgba(10,23,41,0.72), rgba(10,23,41,0.55));
  border: 1px solid rgba(226, 199, 154, 0.4);
  box-shadow: 0 30px 80px rgba(0,0,0,0.4), inset 0 1px 0 rgba(226,199,154,0.15);
  position: relative;
}
.hero-stats::before {
  content: "";
  position: absolute;
  top: -1px; left: 24px; right: 24px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--gold-bright), transparent);
}
.hero-stat-value {
  font-size: 52px;
  letter-spacing: -0.03em;
  background: linear-gradient(180deg, #f3dca8, var(--gold));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.hero-stat-value small {
  background: none;
  -webkit-text-fill-color: var(--gold-light);
  color: var(--gold-light);
  font-size: 0.34em;
}

/* === 数字パネルを劇的に === */
.big-numbers-row {
  border-top: none;
  border-bottom: none;
  background: linear-gradient(180deg, var(--paper-warm), var(--white));
  box-shadow: 0 30px 80px rgba(10,23,41,0.08);
  position: relative;
}
.big-numbers-row::before, .big-numbers-row::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.big-numbers-row::before { top: 0; }
.big-numbers-row::after { bottom: 0; }
.big-number {
  padding: var(--sp-10) var(--sp-5);
  border-right: 1px solid rgba(176, 136, 85, 0.18);
}
.big-number-value {
  font-size: clamp(64px, 7.5vw, 120px);
  letter-spacing: -0.05em;
  background: linear-gradient(180deg, var(--ink-deep) 0%, var(--ink-mid) 70%, var(--gold-deep) 130%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.big-number-label {
  font-size: 12.5px;
  letter-spacing: 0.32em;
  color: var(--gold-deep);
  font-weight: 500;
}

/* === セクションタイトルを大胆に === */
.section-title {
  font-size: clamp(36px, 4.8vw, 64px);
  line-height: 1.32;
  letter-spacing: 0.02em;
}
.section-title em {
  background: linear-gradient(transparent 60%, rgba(176,136,85,0.22) 60%, rgba(176,136,85,0.22) 92%, transparent 92%);
  border-bottom: none;
  padding: 0 4px;
  color: var(--ink-deep);
  font-weight: 700;
}
.section-dark .section-title em {
  background: linear-gradient(transparent 60%, rgba(226,199,154,0.3) 60%, rgba(226,199,154,0.3) 92%, transparent 92%);
  color: var(--gold-bright);
}
.chapter-mark {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11.5px;
  color: var(--gold);
  letter-spacing: 0.5em;
}
.chapter-mark::before, .chapter-mark::after { width: 48px; }

/* === ペルソナカードに金の装飾と存在感 === */
.persona-card {
  padding: var(--sp-9) var(--sp-7) var(--sp-7);
  border: 1px solid var(--line-soft);
  box-shadow: 0 8px 30px rgba(10,23,41,0.05);
  background: linear-gradient(180deg, var(--white) 0%, var(--cream) 100%);
}
.persona-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--gold-light), var(--gold-deep));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--t);
}
.persona-card::after {
  content: "";
  position: absolute;
  top: 18px; right: 18px;
  width: 22px; height: 22px;
  border-top: 1px solid var(--gold);
  border-right: 1px solid var(--gold);
  opacity: 0.6;
}
.persona-card:hover { transform: translateY(-8px); box-shadow: 0 30px 70px rgba(10,23,41,0.18); border-color: var(--gold); }
.persona-card:hover::before { transform: scaleX(1); }
.persona-stage-num {
  font-size: 76px;
  background: linear-gradient(180deg, var(--ink-deep), var(--gold-deep));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* === 比較表をプロらしく === */
.compare-tbl {
  box-shadow: 0 30px 80px rgba(10,23,41,0.10);
  border: none;
}
.compare-tbl thead th {
  padding: var(--sp-7) var(--sp-4);
  font-size: 14.5px;
}
.compare-tbl thead th.hilite {
  background: linear-gradient(180deg, var(--ink) 0%, var(--ink-deep) 100%);
  position: relative;
  font-size: 16px;
  letter-spacing: 0.12em;
}
.compare-tbl thead th.hilite::before {
  height: 4px;
  background: linear-gradient(90deg, var(--gold-bright), var(--gold-deep));
}
.compare-tbl thead th.hilite::after {
  content: "";
  position: absolute;
  bottom: -1px; left: 0; right: 0;
  height: 1px;
  background: var(--gold);
}
.compare-tbl tbody td.hilite-strong {
  background: linear-gradient(180deg, rgba(176,136,85,0.14), rgba(176,136,85,0.08));
  color: var(--ink-deep);
  font-weight: 700;
  font-size: 13.5px;
  position: relative;
}
.compare-tbl tbody tr:hover td.hilite-strong { background: rgba(176,136,85,0.18); }
.compare-tbl tbody tr { transition: background var(--t-fast); }
.compare-tbl tbody tr:hover { background: rgba(176,136,85,0.04); }

/* === 強み3カードに金の角飾り === */
.strength-card {
  padding: var(--sp-9) var(--sp-7) var(--sp-8);
  box-shadow: 0 8px 30px rgba(10,23,41,0.05);
}
.strength-card::after {
  content: "";
  position: absolute;
  bottom: 18px; right: 18px;
  width: 28px; height: 28px;
  border-bottom: 1px solid var(--gold);
  border-right: 1px solid var(--gold);
  opacity: 0.5;
}
.strength-card::before { height: 3px; background: linear-gradient(90deg, var(--gold-light), var(--gold-deep)); transform: scaleX(0.18); }
.strength-card:hover { box-shadow: 0 32px 80px rgba(10,23,41,0.18); }
.strength-card:hover::before { transform: scaleX(1); }
.strength-num strong {
  font-size: 84px;
  background: linear-gradient(180deg, var(--ink-deep) 0%, var(--gold-deep) 130%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* === ボタンを存在感ある CTA に === */
.btn { padding: 20px 42px; font-size: 14px; letter-spacing: 0.22em; }
.btn-primary {
  background: linear-gradient(135deg, var(--ink-deep) 0%, var(--ink) 100%);
  box-shadow: 0 14px 40px rgba(10,23,41,0.35), inset 0 1px 0 rgba(226,199,154,0.15);
  border: 1px solid var(--gold);
  position: relative;
  overflow: hidden;
}
.btn-primary::after {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px solid rgba(226,199,154,0.25);
  pointer-events: none;
  transition: var(--t);
}
.btn-primary:hover { box-shadow: 0 18px 48px rgba(10,23,41,0.45), inset 0 1px 0 rgba(226,199,154,0.3); transform: translateY(-2px); }
.btn-primary:hover::after { inset: 7px; border-color: rgba(226,199,154,0.45); }
.btn-gold {
  background: linear-gradient(135deg, var(--gold-bright) 0%, var(--gold) 50%, var(--gold-deep) 100%);
  color: var(--ink-deep);
  border: 1px solid var(--gold-deep);
  box-shadow: 0 12px 36px rgba(130, 99, 53, 0.35), inset 0 1px 0 rgba(255,255,255,0.3);
  font-weight: 700;
}
.btn-gold:hover { transform: translateY(-2px); box-shadow: 0 18px 48px rgba(130, 99, 53,0.45), inset 0 1px 0 rgba(255,255,255,0.4); }
.btn-xl { padding: 24px 54px; font-size: 15px; letter-spacing: 0.26em; }

/* === 心配・お悩みグリッド(concern)に深み === */
.concerns-grid { gap: 0; }
.concern-item {
  background: var(--white);
  padding: var(--sp-8) var(--sp-7);
  border: 1px solid var(--line-soft);
  margin: -1px 0 0 -1px;
  position: relative;
  transition: var(--t);
}
.concern-item:hover {
  z-index: 1;
  border-color: var(--gold);
  box-shadow: 0 24px 60px rgba(10,23,41,0.14);
  transform: translateY(-4px);
}
.concern-item::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 0; height: 2px;
  background: var(--gold);
  transition: width var(--t);
}
.concern-item:hover::before { width: 100%; }

/* === Voice cards === */
.voice-card {
  background: var(--white);
  border: 1px solid var(--line-soft);
  box-shadow: 0 6px 24px rgba(10,23,41,0.06);
  transition: var(--t);
}
.voice-card:hover { box-shadow: 0 24px 60px rgba(10,23,41,0.16); transform: translateY(-4px); border-color: var(--gold-light); }
.voice-photo {
  background: linear-gradient(135deg, var(--ink-soft), var(--ink-deep));
  border: 2px solid var(--gold);
}

/* === Pillarsカードに磨き === */
.pillar-card {
  padding: var(--sp-9) var(--sp-6);
  background: linear-gradient(180deg, var(--white), var(--cream));
  border: 1px solid var(--line-soft);
  box-shadow: 0 6px 24px rgba(10,23,41,0.05);
  transition: var(--t);
  position: relative;
  overflow: hidden;
}
.pillar-card::before {
  content: "";
  position: absolute;
  top: -50%; right: -50%;
  width: 100%; height: 100%;
  background: radial-gradient(circle, rgba(176,136,85,0.12), transparent 60%);
  opacity: 0;
  transition: opacity var(--t);
}
.pillar-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 30px 70px rgba(10,23,41,0.18);
  border-color: var(--gold);
}
.pillar-card:hover::before { opacity: 1; }
.pillar-num {
  background: linear-gradient(180deg, var(--ink-deep), var(--gold-deep));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* === 権威バーをよりリッチに === */
.authority-section {
  background: linear-gradient(180deg, var(--paper) 0%, var(--cream) 100%);
  padding: var(--sp-10) var(--sp-7);
}
.authority-grid { gap: 0; padding: var(--sp-6) 0; border-top: 1px solid rgba(176,136,85,0.18); border-bottom: 1px solid rgba(176,136,85,0.18); }
.authority-item { transition: var(--t); padding: var(--sp-6) var(--sp-4); }
.authority-item:hover { background: var(--white); transform: translateY(-2px); }
.authority-item-name { font-size: 13px; line-height: 1.7; }
.authority-label { font-size: 12px; letter-spacing: 0.6em; }

/* === Material banner はもっとドラマチックに === */
.material-banner { padding: var(--sp-11) var(--sp-7); }
.material-banner::before {
  background-image:
    linear-gradient(105deg, rgba(7,16,30,0.95) 30%, rgba(17,37,69,0.85) 70%),
    radial-gradient(ellipse at 90% 30%, rgba(176,136,85,0.25), transparent 50%),
    url('https://images.unsplash.com/photo-1450101499163-c8848c66ca85?w=1800&q=85&auto=format&fit=crop');
}
.material-banner h2 {
  font-size: clamp(32px, 4.2vw, 52px);
  line-height: 1.4;
  letter-spacing: 0.03em;
}
.material-mockup {
  box-shadow: 0 60px 120px rgba(0,0,0,0.6), 0 30px 60px rgba(176,136,85,0.25);
  transition: var(--t);
}
.material-mockup:hover { transform: rotate(0) translateY(-8px) scale(1.02); }

/* === Final CTAをスケールアップ === */
.final-cta {
  position: relative;
  overflow: hidden;
}
.final-cta::after {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.final-cta h2 {
  font-size: clamp(40px, 5.5vw, 76px);
  line-height: 1.32;
  text-shadow: 0 6px 30px rgba(0,0,0,0.4);
}
.final-cta h2 em {
  background: linear-gradient(135deg, var(--gold-bright), #f3dca8, var(--gold-light));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* === Case study before/after を圧倒的に === */
.case-stat {
  font-size: clamp(56px, 7vw, 96px) !important;
  letter-spacing: -0.03em;
  line-height: 1.05;
}
.case-savings-value {
  font-size: clamp(64px, 8vw, 110px) !important;
  background: linear-gradient(180deg, var(--gold-bright), var(--gold-deep));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* === Sticky CTA をもっとプレミアムに === */
.sticky-cta {
  background: linear-gradient(180deg, rgba(10,23,41,0.97) 0%, rgba(7,16,30,0.99) 100%);
  border-top: 1px solid var(--gold);
  box-shadow: 0 -16px 48px rgba(0,0,0,0.35);
  padding: var(--sp-4) var(--sp-7);
}
.sticky-cta::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold-bright), transparent);
}
.sticky-cta-btn {
  padding: 12px 26px;
  font-size: 12.5px;
  letter-spacing: 0.18em;
}
.sticky-cta-btn.primary {
  background: linear-gradient(135deg, var(--gold-bright), var(--gold), var(--gold-deep));
  font-weight: 700;
  box-shadow: 0 6px 18px rgba(176,136,85,0.45);
}

/* === Header glassに === */
.site-header {
  background: rgba(250, 247, 240, 0.92);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(176,136,85,0.15);
  box-shadow: 0 1px 0 rgba(255,255,255,0.5);
}

/* === Page hero (sub pages) もスケールアップ === */
.page-hero h1 {
  font-size: clamp(40px, 5.5vw, 76px) !important;
  line-height: 1.32 !important;
}
.page-hero h1 em {
  background: linear-gradient(135deg, var(--gold-deep), var(--gold));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  border-bottom: none !important;
}

@media (max-width: 1024px) {
  .hero-h1 { font-size: clamp(34px, 8vw, 54px); }
  .big-number-value { font-size: clamp(48px, 12vw, 72px); }
  .section-title { font-size: clamp(28px, 6vw, 42px); }
  .strength-num strong { font-size: 56px; }
  .persona-stage-num { font-size: 56px; }
}

/* ===========================================================
   TYPOGRAPHY SYSTEM — 全サイト統一の階層・改行・リズム
   =========================================================== */

/* 全テキスト要素にpaltで日本語の詰めを最適化 */
body, h1, h2, h3, h4, h5, h6, p, span, div, li, a, button, input, textarea, label, td, th {
  font-feature-settings: "palt" 1;
}

/* 見出しの基本ルール — 助詞先頭を避ける + 単語途中で切らない */
h1, h2, h3, h4 {
  word-break: keep-all;
  overflow-wrap: anywhere;
  text-wrap: pretty; /* Modern browsers: balance line lengths */
}

/* 本文 — 美しい段落 */
p {
  text-wrap: pretty;
  hanging-punctuation: allow-end;
}

/* レスポンシブ改行ユーティリティ */
.br-md { display: none; }                           /* モバイルでは改行しない */
@media (min-width: 768px) { .br-md { display: inline; } }
.br-lg { display: none; }
@media (min-width: 1024px) { .br-lg { display: inline; } }
.br-mobile-only { display: inline; }
@media (min-width: 768px) { .br-mobile-only { display: none; } }

/* ヒーロー H1 — 視認性最優先 */
.hero-h1 {
  line-height: 1.4 !important;
  letter-spacing: 0.05em !important;
  font-size: clamp(38px, 5.4vw, 76px) !important;
  text-shadow: 0 6px 30px rgba(0,0,0,0.5);
}
.hero-h1 br { line-height: inherit; }
.hero-h1 .accent {
  font-family: var(--sans);
  font-style: normal;
  font-weight: 600;
  font-size: 0.2em;
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.22em;
  margin-top: var(--sp-5);
  display: block;
  text-shadow: none;
}

/* ヒーロー sub — 行間と字間最適化 */
.hero-sub {
  font-size: 15px !important;
  line-height: 2.2 !important;
  letter-spacing: 0.07em !important;
  margin-bottom: var(--sp-6);
}

/* セクション H2 — 一貫した階層 */
.section-title, .ceo-trust-h, .usp-title, .material-banner h2, .final-cta h2 {
  font-size: clamp(28px, 3.6vw, 48px) !important;
  line-height: 1.6 !important;
  letter-spacing: 0.06em !important;
}

/* カードタイトル H3 — 統一サイズ */
.persona-title, .strength-title, .concern-title, .tool-h, .usp-h, .voice-quote, .pillar-title, .blog-title, .failure-title, .case-detail-h {
  line-height: 1.65 !important;
  letter-spacing: 0.05em !important;
}

/* 本文 — 読みやすさ */
.section-lead, .strength-body, .concern-body, .tool-p, .usp-p, .ceo-trust-lead, .persona-checklist li, .blog-excerpt, .failure-body {
  line-height: 2.05 !important;
  letter-spacing: 0.05em !important;
}

/* 説明文の最大幅 — 1行60-80文字に収める */
.section-lead { max-width: 680px; }
.hero-sub { max-width: 560px; }
.ceo-trust-lead { max-width: 640px; }

/* 句読点ぶら下げ + タイトルバランス */
.persona-title, .strength-title, .tool-h, .usp-h, .ceo-trust-h, .section-title {
  text-wrap: balance;
}

/* 強調 strong — オレンジハイライト+ウェイト */
strong { font-weight: 700; }

/* 数字フォントの統一 — タビュラー */
.hero-stat-value, .big-number-value, .case-fact-num, .case-stat, .savings-num {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}

/* リンクの基本動作 */
a { text-decoration: none; transition: color 0.2s; }
a:focus-visible { outline: 2px solid var(--brand-orange); outline-offset: 3px; border-radius: 2px; }

/* ボタンの focus-visible */
.btn:focus-visible { outline: 3px solid rgba(226, 199, 154,0.4); outline-offset: 2px; }

/* セクション間の余白を baseline grid で揃える */
.section, .usp-triangle, .free-tools, .ceo-trust, .persona-routing, .compare-section, .material-banner, .final-cta, .authority-section {
  padding-top: clamp(var(--sp-9), 9vw, var(--sp-12));
  padding-bottom: clamp(var(--sp-9), 9vw, var(--sp-12));
}
.authority-section {
  padding-top: var(--sp-7);
  padding-bottom: var(--sp-7);
}

/* セクション head の下マージン統一 */
.section-head { margin-bottom: clamp(var(--sp-7), 6vw, var(--sp-10)); }

/* タイトル下の lead との余白 */
.section-title + .section-lead,
.usp-title + .section-lead,
.material-banner h2 + p,
.final-cta h2 + p {
  margin-top: clamp(var(--sp-4), 2vw, var(--sp-6));
}

/* ===========================================================
   CONVERSION UX — Scroll Reveal · Smart Header · FAB · Trust Pulse
   =========================================================== */

/* Smart sticky header */
.site-header { transition: transform 0.35s cubic-bezier(0.22,0.61,0.36,1), background 0.3s, box-shadow 0.3s; will-change: transform; }
.site-header.is-scrolled { background: rgba(255,255,255,0.96); box-shadow: 0 4px 20px rgba(15,35,66,0.08); }
.site-header.is-hidden { transform: translateY(-100%); }

/* Scroll reveal */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.85s cubic-bezier(0.22,0.61,0.36,1), transform 0.85s cubic-bezier(0.22,0.61,0.36,1); }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
.usp-grid .reveal:nth-child(2) { transition-delay: 0.1s; }
.usp-grid .reveal:nth-child(3) { transition-delay: 0.2s; }
.tools-grid .reveal:nth-child(2) { transition-delay: 0.08s; }
.tools-grid .reveal:nth-child(3) { transition-delay: 0.16s; }
.tools-grid .reveal:nth-child(4) { transition-delay: 0.24s; }
.tools-grid .reveal:nth-child(5) { transition-delay: 0.32s; }
.tools-grid .reveal:nth-child(6) { transition-delay: 0.4s; }
.persona-grid .reveal:nth-child(2) { transition-delay: 0.1s; }
.persona-grid .reveal:nth-child(3) { transition-delay: 0.2s; }
.strengths-grid .reveal:nth-child(2) { transition-delay: 0.1s; }
.strengths-grid .reveal:nth-child(3) { transition-delay: 0.2s; }
.concerns-grid .reveal:nth-child(2),
.concerns-grid .reveal:nth-child(5) { transition-delay: 0.08s; }
.concerns-grid .reveal:nth-child(3),
.concerns-grid .reveal:nth-child(6) { transition-delay: 0.16s; }
.big-numbers-row .reveal:nth-child(2) { transition-delay: 0.1s; }
.big-numbers-row .reveal:nth-child(3) { transition-delay: 0.2s; }
.big-numbers-row .reveal:nth-child(4) { transition-delay: 0.3s; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* Mobile floating action buttons */
.fab-stack {
  position: fixed;
  right: 14px;
  bottom: 92px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  z-index: 80;
}
.fab {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  color: var(--white);
  font-family: var(--sans);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.04em;
  box-shadow: 0 12px 28px rgba(15,35,66,0.32);
  transition: transform 0.25s, box-shadow 0.25s;
  text-decoration: none;
}
.fab:active { transform: scale(0.94); }
.fab-tel { background: var(--brand-orange); }
.fab-line { background: #06c755; }
.fab-line-text { color: var(--white); font-weight: 800; letter-spacing: 0.06em; font-size: 14px; }
.fab:hover { box-shadow: 0 18px 36px rgba(15,35,66,0.45); transform: translateY(-2px); }
@media (min-width: 1025px) { .fab-stack { display: none; } }

/* Trust Pulse — recent activity indicator */
.trust-pulse {
  position: fixed;
  left: 14px;
  bottom: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--white);
  border: 1px solid var(--brand-line);
  border-radius: 100px;
  padding: 10px 18px 10px 12px;
  box-shadow: 0 12px 32px rgba(15,35,66,0.12);
  z-index: 70;
  font-family: var(--sans);
  font-size: 12.5px;
  color: var(--brand-text);
  letter-spacing: 0.04em;
  transform: translateX(-120%);
  transition: transform 0.5s cubic-bezier(0.22,0.61,0.36,1);
  max-width: 320px;
}
.trust-pulse.is-shown { transform: translateX(0); }
.trust-pulse-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #06c755;
  flex-shrink: 0;
  position: relative;
}
.trust-pulse-dot::after {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  background: rgba(6, 199, 85, 0.4);
  animation: pulse-ring 1.8s ease-out infinite;
}
@keyframes pulse-ring {
  0% { transform: scale(0.7); opacity: 1; }
  100% { transform: scale(2.2); opacity: 0; }
}
.trust-pulse-text strong { color: var(--brand-orange); font-weight: 700; }
@media (max-width: 768px) { .trust-pulse { display: none; } }

/* Form field focus polish */
.form-row input, .form-row select, .form-row textarea,
.field input, .field select, .field textarea {
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.form-row input:focus, .form-row select:focus, .form-row textarea:focus,
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none;
  border-color: var(--brand-orange);
  background: var(--white);
  box-shadow: 0 0 0 3px rgba(226, 199, 154,0.15);
}
.field-label { transition: color 0.2s; }
.field:focus-within .field-label { color: var(--brand-orange); }

/* Submit button polish */
.submit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  background: var(--brand-orange) !important;
  color: var(--white) !important;
  border: none !important;
  font-family: var(--sans);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0.18em;
  padding: 22px 56px;
  border-radius: 2px;
  cursor: pointer;
  box-shadow: 0 12px 32px rgba(226, 199, 154,0.4) !important;
  transition: all 0.3s cubic-bezier(0.22,0.61,0.36,1);
  text-decoration: none;
  position: relative;
  overflow: hidden;
}
.submit-btn::after { content: "→"; font-size: 18px; transition: transform 0.3s; }
.submit-btn:hover { background: var(--brand-orange-deep) !important; transform: translateY(-3px); box-shadow: 0 18px 44px rgba(226, 199, 154,0.5) !important; }
.submit-btn:hover::after { transform: translateX(6px); }

/* Scarcity Badge */
.scarcity-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(226, 199, 154,0.12);
  border: 1px solid rgba(226, 199, 154,0.4);
  color: var(--brand-orange-deep);
  font-family: var(--sans);
  font-weight: 700;
  font-size: 11.5px;
  letter-spacing: 0.08em;
  padding: 6px 12px;
  border-radius: 100px;
  margin-bottom: var(--sp-3);
}
.scarcity-badge::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--brand-orange);
  position: relative;
}
.scarcity-badge.in-hero {
  background: rgba(255,255,255,0.12);
  border-color: rgba(232,132,86,0.6);
  color: var(--brand-orange-bright);
  backdrop-filter: blur(6px);
}

/* CTA arrow micro-interaction */
.btn-arrow::after { content: "→"; margin-left: 8px; transition: transform 0.3s; display: inline-block; }
.btn-arrow:hover::after { transform: translateX(6px); }

/* Hero CTA polish */
.hero-cta-row .btn { box-shadow: 0 14px 36px rgba(0,0,0,0.32); }
.hero-cta-row .btn-primary { box-shadow: 0 14px 36px rgba(226, 199, 154,0.5); }
.hero-cta-row .btn:hover { transform: translateY(-3px); }

/* ===========================================================
   CEO TRUST — 不動産のプロ社長が毎回ご面談
   =========================================================== */
.ceo-trust {
  background: linear-gradient(180deg, var(--white) 0%, var(--brand-warm-bg) 100%);
  padding: var(--sp-12) var(--sp-7);
  border-bottom: 1px solid var(--brand-line);
}
.ceo-trust-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: var(--sp-10);
  align-items: center;
}
.ceo-trust-photo-col { position: relative; }
.ceo-trust-photo {
  width: 100%;
  aspect-ratio: 4/5;
  background-image: url('../images/brand/ceo-inoguchi.jpg');
  background-size: cover;
  background-position: center 20%;
  position: relative;
  z-index: 1;
  filter: contrast(1.04) saturate(1.05);
}
.ceo-trust-frame {
  position: absolute;
  top: 22px;
  left: 22px;
  right: -22px;
  bottom: -22px;
  border: 2px solid var(--brand-orange);
  z-index: 0;
}
.ceo-trust-caption {
  position: absolute;
  bottom: var(--sp-7);
  left: 0;
  right: 0;
  background: var(--white);
  padding: var(--sp-5) var(--sp-6);
  margin: 0 var(--sp-5);
  z-index: 2;
  box-shadow: 0 16px 40px rgba(15,35,66,0.16);
  border-left: 3px solid var(--brand-orange);
}
.ceo-trust-name-en {
  font-family: "EB Garamond", serif;
  font-style: italic;
  font-size: 13px;
  color: var(--brand-orange);
  letter-spacing: 0.18em;
  margin-bottom: 4px;
  font-weight: 500;
}
.ceo-trust-name-jp {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: 17px;
  color: var(--brand-navy-deep);
  letter-spacing: 0.06em;
}

.ceo-trust-text-col { padding-left: var(--sp-5); }
.ceo-trust-tag {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 12px;
  color: var(--brand-orange);
  letter-spacing: 0.4em;
  margin-bottom: var(--sp-5);
  text-transform: uppercase;
}
.ceo-trust-h {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.55;
  color: var(--brand-navy-deep);
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-7);
  font-feature-settings: "palt" 1;
}
.ceo-trust-h em {
  color: var(--brand-orange);
  font-weight: 700;
  font-style: normal;
  background: linear-gradient(transparent 62%, rgba(226, 199, 154,0.2) 62%, rgba(226, 199, 154,0.2) 92%, transparent 92%);
  padding: 0 6px;
}
.ceo-trust-lead {
  font-family: var(--sans);
  font-size: 14.5px;
  line-height: 2.1;
  color: var(--brand-text);
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-4);
  font-feature-settings: "palt" 1;
}
.ceo-trust-lead strong {
  color: var(--brand-navy-deep);
  font-weight: 700;
  background: linear-gradient(transparent 65%, rgba(226, 199, 154,0.18) 65%);
  padding: 0 2px;
}
.ceo-trust-creds {
  margin: var(--sp-7) 0;
  padding: var(--sp-6);
  background: var(--white);
  border: 1px solid var(--brand-line);
  border-left: 3px solid var(--brand-orange);
}
.ceo-trust-creds-label {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 11px;
  color: var(--brand-orange);
  letter-spacing: 0.32em;
  margin-bottom: var(--sp-4);
  text-transform: uppercase;
}
.ceo-trust-creds ul { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 6px var(--sp-4); }
.ceo-trust-creds li {
  font-family: var(--sans);
  font-size: 12.5px;
  line-height: 1.85;
  color: var(--brand-text);
  letter-spacing: 0.04em;
  padding-left: 22px;
  position: relative;
}
.ceo-trust-creds li::before {
  content: "✓";
  color: var(--brand-orange);
  font-weight: 700;
  position: absolute;
  left: 0;
  top: 1px;
  font-size: 13px;
}
.ceo-trust-cta-row { display: flex; gap: var(--sp-4); flex-wrap: wrap; }

@media (max-width: 1024px) {
  .ceo-trust-inner { grid-template-columns: 1fr; gap: var(--sp-8); }
  .ceo-trust-photo-col { max-width: 380px; margin: 0 auto; width: 100%; }
  .ceo-trust-text-col { padding-left: 0; }
  .ceo-trust-creds ul { grid-template-columns: 1fr; }
  .ceo-trust-cta-row { flex-direction: column; }
  .ceo-trust-cta-row .btn { width: 100%; }
}

/* ===========================================================
   USP TRIANGLE — 3つの差別化軸
   =========================================================== */
.usp-triangle {
  background: linear-gradient(180deg, var(--brand-warm-bg) 0%, var(--white) 100%);
  padding: var(--sp-11) var(--sp-7);
  border-bottom: 1px solid var(--brand-line);
}
.usp-inner { max-width: 1280px; margin: 0 auto; }
.usp-tag {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 12px;
  color: var(--brand-orange);
  letter-spacing: 0.4em;
  text-align: center;
  margin-bottom: var(--sp-5);
  text-transform: uppercase;
}
.usp-title {
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(32px, 4.2vw, 54px);
  font-weight: 600;
  text-align: center;
  color: var(--brand-navy-deep);
  line-height: 1.5;
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-10);
  font-feature-settings: "palt" 1;
}
.usp-title em { color: var(--brand-orange); font-weight: 700; background: linear-gradient(transparent 62%, rgba(226, 199, 154,0.18) 62%, rgba(226, 199, 154,0.18) 92%, transparent 92%); padding: 0 6px; font-style: normal; }
.usp-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); }
.usp-card {
  background: var(--white);
  padding: var(--sp-9) var(--sp-7);
  border: 1px solid var(--brand-line);
  border-radius: 4px;
  box-shadow: 0 6px 24px rgba(15,35,66,0.05);
  position: relative;
  transition: all 0.35s cubic-bezier(0.22,0.61,0.36,1);
  display: flex;
  flex-direction: column;
}
.usp-card.highlight {
  background: linear-gradient(180deg, var(--brand-navy-deep) 0%, var(--brand-navy) 100%);
  color: var(--white);
  border: none;
  box-shadow: 0 30px 70px rgba(15,35,66,0.25);
  transform: translateY(-12px);
}
.usp-card:hover { transform: translateY(-6px); box-shadow: 0 30px 60px rgba(15,35,66,0.15); border-color: var(--brand-orange); }
.usp-card.highlight:hover { transform: translateY(-18px); box-shadow: 0 40px 90px rgba(15,35,66,0.32); }
.usp-icon-wrap { display: flex; align-items: baseline; gap: var(--sp-4); margin-bottom: var(--sp-5); padding-bottom: var(--sp-5); border-bottom: 1px solid var(--brand-line); }
.usp-card.highlight .usp-icon-wrap { border-bottom-color: rgba(255,255,255,0.18); }
.usp-icon {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: 56px;
  line-height: 1;
  color: var(--brand-orange);
  letter-spacing: -0.04em;
}
.usp-card.highlight .usp-icon { color: var(--brand-orange-bright); }
.usp-axis {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.32em;
  color: var(--brand-text-soft);
  text-transform: uppercase;
}
.usp-card.highlight .usp-axis { color: var(--brand-orange-bright); }
.usp-h {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: 24px;
  line-height: 1.55;
  color: var(--brand-navy-deep);
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-5);
  font-feature-settings: "palt" 1;
}
.usp-card.highlight .usp-h { color: var(--white); }
.usp-h em { color: var(--brand-orange); font-weight: 700; font-style: normal; }
.usp-card.highlight .usp-h em { color: var(--brand-orange-bright); }
.usp-p {
  font-family: var(--sans);
  font-size: 13.5px;
  line-height: 2;
  color: var(--brand-text);
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-6);
  flex: 1;
}
.usp-card.highlight .usp-p { color: rgba(255,255,255,0.86); }
.usp-p strong { color: var(--brand-navy-deep); font-weight: 700; }
.usp-card.highlight .usp-p strong { color: var(--brand-orange-bright); }
.usp-list { list-style: none; padding-top: var(--sp-5); border-top: 1px dashed var(--brand-line); }
.usp-card.highlight .usp-list { border-top-color: rgba(255,255,255,0.18); }
.usp-list li {
  font-family: var(--sans);
  font-size: 12.5px;
  line-height: 2.2;
  color: var(--brand-text-soft);
  padding-left: 22px;
  position: relative;
  letter-spacing: 0.04em;
}
.usp-card.highlight .usp-list li { color: rgba(255,255,255,0.78); }
.usp-list li::before {
  content: "✓";
  color: var(--brand-orange);
  font-weight: 700;
  position: absolute;
  left: 0;
  top: 4px;
  font-size: 13px;
}
.usp-card.highlight .usp-list li::before { color: var(--brand-orange-bright); }
@media (max-width: 1024px) {
  .usp-grid { grid-template-columns: 1fr; }
  .usp-card.highlight { transform: none; }
}

/* ===========================================================
   WHY FUKUOKA — 福岡市特化の根拠データ + 7区マップ
   =========================================================== */
.why-fukuoka {
  background: linear-gradient(180deg, var(--brand-warm-bg) 0%, var(--white) 100%);
  padding: var(--sp-12) var(--sp-7);
  position: relative;
  overflow: hidden;
}
.why-fukuoka::before {
  content: "";
  position: absolute;
  top: 0; right: -10%;
  width: 60%; height: 100%;
  background-image: url('../images/hero/fukuoka-tower-night.jpg');
  background-size: cover;
  background-position: center;
  opacity: 0.05;
  pointer-events: none;
}
.why-fukuoka-inner { max-width: 1280px; margin: 0 auto; position: relative; z-index: 1; }
.fukuoka-data-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
  margin-bottom: var(--sp-12);
}
.fukuoka-data-card {
  background: var(--white);
  padding: var(--sp-7);
  border: 1px solid var(--brand-line);
  border-top: 3px solid var(--brand-orange);
  border-radius: 4px;
  box-shadow: 0 6px 24px rgba(15,35,66,0.05);
  transition: all 0.3s cubic-bezier(0.22,0.61,0.36,1);
}
.fukuoka-data-card:hover { transform: translateY(-4px); box-shadow: 0 24px 56px rgba(15,35,66,0.14); }
.fukuoka-data-en {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 11px;
  color: var(--brand-orange);
  letter-spacing: 0.32em;
  margin-bottom: var(--sp-4);
  text-transform: uppercase;
}
.fukuoka-data-num {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: clamp(40px, 4.5vw, 64px);
  line-height: 1.05;
  color: var(--brand-navy-deep);
  letter-spacing: -0.02em;
  margin-bottom: var(--sp-5);
  font-variant-numeric: tabular-nums;
}
.fukuoka-data-num small {
  font-size: 0.42em;
  color: var(--brand-text-soft);
  font-weight: 400;
  margin-left: 4px;
  letter-spacing: 0.06em;
  font-family: var(--sans);
}
.fukuoka-data-title {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 1.65;
  color: var(--brand-navy-deep);
  letter-spacing: 0.04em;
  margin-bottom: var(--sp-3);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--brand-line);
}
.fukuoka-data-desc {
  font-family: var(--sans);
  font-size: 13px;
  line-height: 2;
  color: var(--brand-text-soft);
  letter-spacing: 0.04em;
}

/* === 7-Ward Map === */
.ward-map-section { padding-top: var(--sp-9); border-top: 1px dashed var(--brand-line); }
.ward-map-head { text-align: center; margin-bottom: var(--sp-8); }
.ward-map-tag {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 12px;
  color: var(--brand-orange);
  letter-spacing: 0.4em;
  margin-bottom: var(--sp-4);
  text-transform: uppercase;
}
.ward-map-h {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: clamp(28px, 3.4vw, 44px);
  color: var(--brand-navy-deep);
  line-height: 1.55;
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-4);
}
.ward-map-h em {
  font-style: normal;
  color: var(--brand-orange);
  font-weight: 700;
  background: linear-gradient(transparent 62%, rgba(226, 199, 154,0.2) 62%, rgba(226, 199, 154,0.2) 92%, transparent 92%);
  padding: 0 6px;
}
.ward-map-p {
  font-family: var(--sans);
  font-size: 14.5px;
  color: var(--brand-text-soft);
  line-height: 2.05;
  letter-spacing: 0.05em;
}
.ward-map-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: var(--sp-3);
  max-width: 1100px;
  margin: 0 auto var(--sp-7);
}
.ward-card {
  display: block;
  background: var(--white);
  border: 1px solid var(--brand-line);
  padding: var(--sp-6) var(--sp-3);
  text-align: center;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: transform 0.5s cubic-bezier(0.22,0.61,0.36,1), background 0.4s ease, border-color 0.4s ease, box-shadow 0.5s cubic-bezier(0.22,0.61,0.36,1), color 0.4s ease;
  transition: all 0.3s cubic-bezier(0.22,0.61,0.36,1);
  position: relative;
  overflow: hidden;
  text-decoration: none;
}
.ward-card.ward-hakata, .ward-card:hover {
  background: linear-gradient(180deg, var(--brand-navy-deep), var(--brand-navy));
  color: var(--white);
  border-color: var(--brand-orange);
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(15,35,66,0.25);
}
.ward-num {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 11px;
  color: var(--brand-orange);
  letter-spacing: 0.18em;
  margin-bottom: var(--sp-3);
}
.ward-name {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: 19px;
  color: var(--brand-navy-deep);
  letter-spacing: 0.06em;
  margin-bottom: 4px;
}
.ward-card.ward-hakata .ward-name, .ward-card:hover .ward-name { color: var(--white); }
.ward-en {
  font-family: "EB Garamond", serif;
  font-style: italic;
  font-size: 12px;
  color: var(--brand-orange);
  letter-spacing: 0.12em;
  margin-bottom: var(--sp-3);
}
.ward-card.ward-hakata .ward-en, .ward-card:hover .ward-en { color: var(--brand-orange-bright); }
.ward-attr {
  font-family: var(--sans);
  font-size: 11.5px;
  color: var(--brand-text-soft);
  letter-spacing: 0.06em;
  padding-top: var(--sp-3);
  border-top: 1px solid var(--brand-line);
}
.ward-card.ward-hakata .ward-attr, .ward-card:hover .ward-attr {
  color: rgba(255,255,255,0.78);
  border-top-color: rgba(255,255,255,0.18);
}
.ward-map-cta { text-align: center; }

@media (max-width: 1024px) {
  .fukuoka-data-grid { grid-template-columns: repeat(2, 1fr); }
  .ward-map-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 640px) {
  .fukuoka-data-grid { grid-template-columns: 1fr; }
  .ward-map-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ===========================================================
   ANTI-SALES — 当社が絶対にしない7つのこと
   =========================================================== */
.anti-sales {
  background: linear-gradient(180deg, var(--brand-navy-deep) 0%, var(--brand-navy) 100%);
  color: var(--white);
  padding: var(--sp-12) var(--sp-7);
  position: relative;
  overflow: hidden;
}
.anti-sales::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 80% 20%, rgba(226, 199, 154,0.15), transparent 60%);
  pointer-events: none;
}
.anti-sales-inner { max-width: 1200px; margin: 0 auto; position: relative; z-index: 1; }
.anti-sales .chapter-mark { color: var(--brand-orange-bright); }
.anti-sales .chapter-mark::before, .anti-sales .chapter-mark::after { background: var(--brand-orange-bright); }
.anti-sales .section-title { color: var(--white); }
.anti-sales .section-title em { color: var(--brand-orange-bright); background: linear-gradient(transparent 62%, rgba(232,132,86,0.3) 62%, rgba(232,132,86,0.3) 92%, transparent 92%); }
.anti-sales .section-lead { color: rgba(255,255,255,0.82); }

.promise-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-5);
  margin-top: var(--sp-9);
}
.promise-item {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(232,132,86,0.25);
  padding: var(--sp-6) var(--sp-7);
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: var(--sp-5);
  align-items: start;
  transition: all 0.3s;
}
.promise-item:hover {
  background: rgba(255,255,255,0.08);
  border-color: var(--brand-orange-bright);
  transform: translateY(-3px);
}
.promise-x {
  font-family: "Shippori Mincho B1", serif;
  font-size: 48px;
  font-weight: 600;
  line-height: 1;
  color: var(--brand-orange-bright);
}
.promise-text h4 {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: 18px;
  color: var(--white);
  letter-spacing: 0.06em;
  margin-bottom: var(--sp-3);
  line-height: 1.5;
}
.promise-text p {
  font-family: var(--sans);
  font-size: 13px;
  line-height: 2;
  color: rgba(255,255,255,0.78);
  letter-spacing: 0.04em;
}
@media (max-width: 768px) {
  .promise-grid { grid-template-columns: 1fr; }
}

/* ===========================================================
   CONSULTATION PROCESS — 60分で何が起こるか5ステップ
   =========================================================== */
.process-section {
  background: var(--brand-warm-bg);
  padding: var(--sp-12) var(--sp-7);
}
.process-inner { max-width: 1200px; margin: 0 auto; }
.process-timeline {
  position: relative;
  padding-left: var(--sp-9);
  max-width: 920px;
  margin: 0 auto;
}
.process-timeline::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 12px;
  bottom: 12px;
  width: 2px;
  background: linear-gradient(180deg, var(--brand-orange) 0%, var(--brand-orange-deep) 100%);
}
.process-step {
  position: relative;
  background: var(--white);
  padding: var(--sp-6) var(--sp-7);
  border: 1px solid var(--brand-line);
  border-radius: 4px;
  margin-bottom: var(--sp-5);
  box-shadow: 0 6px 20px rgba(15,35,66,0.06);
  transition: all 0.3s;
}
.process-step:hover { transform: translateX(8px); box-shadow: 0 16px 40px rgba(15,35,66,0.12); border-color: var(--brand-orange); }
.process-step::before {
  content: "";
  position: absolute;
  left: -42px;
  top: 24px;
  width: 14px;
  height: 14px;
  background: var(--brand-orange);
  border: 3px solid var(--brand-warm-bg);
  border-radius: 50%;
  box-shadow: 0 0 0 2px var(--brand-orange);
}
.process-num {
  position: absolute;
  top: 16px;
  right: 28px;
  font-family: "Shippori Mincho B1", serif;
  font-size: 56px;
  font-weight: 600;
  color: var(--brand-warm-bg);
  line-height: 1;
  letter-spacing: -0.04em;
  z-index: 0;
  font-variant-numeric: tabular-nums;
}
.process-time {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 11.5px;
  color: var(--brand-orange);
  letter-spacing: 0.18em;
  margin-bottom: var(--sp-3);
  text-transform: uppercase;
  position: relative;
  z-index: 1;
}
.process-step h4 {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: 21px;
  color: var(--brand-navy-deep);
  letter-spacing: 0.04em;
  margin-bottom: var(--sp-3);
  line-height: 1.55;
  position: relative;
  z-index: 1;
}
.process-step p {
  font-family: var(--sans);
  font-size: 13.5px;
  line-height: 2.05;
  color: var(--brand-text);
  letter-spacing: 0.04em;
  position: relative;
  z-index: 1;
}
.process-cta { text-align: center; margin-top: var(--sp-9); }
.process-cta-note {
  font-family: var(--sans);
  font-size: 12.5px;
  color: var(--brand-text-soft);
  letter-spacing: 0.06em;
  margin-top: var(--sp-4);
}

/* ===========================================================
   FAQ ACCORDION — 不安解消
   =========================================================== */
.faq-section {
  background: var(--white);
  padding: var(--sp-12) var(--sp-7);
}
.faq-inner { max-width: 920px; margin: 0 auto; }
.faq-list { margin-top: var(--sp-7); }
.faq-item {
  background: var(--white);
  border: 1px solid var(--brand-line);
  border-radius: 4px;
  margin-bottom: var(--sp-3);
  transition: all 0.3s;
}
.faq-item:hover { border-color: var(--brand-orange); }
.faq-item[open] { border-color: var(--brand-orange); box-shadow: 0 12px 32px rgba(15,35,66,0.08); }
.faq-item summary {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 1.65;
  color: var(--brand-navy-deep);
  letter-spacing: 0.04em;
  padding: var(--sp-5) var(--sp-6);
  padding-right: 56px;
  cursor: pointer;
  list-style: none;
  position: relative;
  user-select: none;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::before {
  content: "Q";
  font-family: "EB Garamond", serif;
  font-style: italic;
  font-weight: 600;
  color: var(--brand-orange);
  font-size: 18px;
  margin-right: 12px;
  letter-spacing: 0.06em;
}
.faq-item summary::after {
  content: "";
  position: absolute;
  right: var(--sp-6);
  top: 50%;
  width: 14px;
  height: 14px;
  border-right: 2px solid var(--brand-orange);
  border-bottom: 2px solid var(--brand-orange);
  transform: translateY(-70%) rotate(45deg);
  transition: transform 0.3s;
}
.faq-item[open] summary::after { transform: translateY(-30%) rotate(-135deg); }
.faq-item summary:hover { background: var(--brand-warm-bg); }
.faq-body {
  padding: 0 var(--sp-6) var(--sp-6) var(--sp-6);
  font-family: var(--sans);
  font-size: 14px;
  line-height: 2.1;
  color: var(--brand-text);
  letter-spacing: 0.04em;
  border-top: 1px solid var(--brand-line);
  padding-top: var(--sp-5);
  margin-top: var(--sp-3);
  position: relative;
}
.faq-body::before {
  content: "A";
  font-family: "EB Garamond", serif;
  font-style: italic;
  font-weight: 600;
  color: var(--brand-orange);
  font-size: 18px;
  margin-right: 12px;
  letter-spacing: 0.06em;
}

@media (max-width: 768px) {
  .faq-item summary { font-size: 14.5px; padding: var(--sp-4) var(--sp-5); padding-right: 48px; }
  .faq-body { padding: var(--sp-3) var(--sp-5) var(--sp-5); font-size: 13px; }
}

/* ===========================================================
   FREE TOOLS — リードマグネット6つ
   =========================================================== */
.free-tools { background: var(--white); padding: var(--sp-11) var(--sp-7); }
.free-tools-inner { max-width: 1280px; margin: 0 auto; }
.tools-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-4);
  max-width: 1280px;
  margin: 0 auto;
}
@media (max-width: 1024px) {
  .tools-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-4); }
}
@media (max-width: 640px) {
  .tools-grid { grid-template-columns: 1fr; }
}
.tool-card {
  background: var(--white);
  border: 1px solid var(--brand-line);
  border-radius: 4px;
  padding: var(--sp-7);
  transition: all 0.3s cubic-bezier(0.22,0.61,0.36,1);
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}
.tool-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--brand-orange);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s;
}
.tool-card:hover { transform: translateY(-6px); box-shadow: 0 24px 60px rgba(15,35,66,0.14); border-color: var(--brand-orange); }
.tool-card:hover::before { transform: scaleX(1); }
.tool-badge {
  display: inline-block;
  background: var(--brand-orange);
  color: var(--white);
  font-family: var(--sans);
  font-weight: 700;
  font-size: 10.5px;
  letter-spacing: 0.18em;
  padding: 5px 12px;
  border-radius: 2px;
  margin-bottom: var(--sp-4);
  text-transform: uppercase;
  align-self: flex-start;
}
.tool-badge.free { background: var(--brand-navy-deep); }
.tool-h {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: 21px;
  color: var(--brand-navy-deep);
  line-height: 1.55;
  letter-spacing: 0.04em;
  margin-bottom: var(--sp-4);
  font-feature-settings: "palt" 1;
}
.tool-h em { color: var(--brand-orange); font-style: normal; font-weight: 700; }
.tool-p {
  font-family: var(--sans);
  font-size: 13px;
  line-height: 1.95;
  color: var(--brand-text-soft);
  letter-spacing: 0.04em;
  margin-bottom: var(--sp-5);
  flex: 1;
}
.tool-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-5);
}
.tool-meta span {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  background: var(--brand-warm-bg);
  color: var(--brand-orange-deep);
  padding: 4px 10px;
  border-radius: 2px;
}
.tool-cta {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 18px;
  background: var(--brand-warm-bg);
  color: var(--brand-navy-deep);
  font-family: var(--sans);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.1em;
  border-radius: 2px;
  transition: all 0.3s;
  text-align: left;
}
.tool-cta::after { content: "→"; font-size: 16px; transition: transform 0.3s; }
.tool-cta:hover { background: var(--brand-orange); color: var(--white); }
.tool-cta:hover::after { transform: translateX(4px); }
@media (max-width: 1024px) { .tools-grid { grid-template-columns: 1fr; } }

/* =========================================================
   DESIGN v3 — "Smiling Tomorrow" 不動産が売れる写真主役の温かいデザイン
   asupartner.comの実ブランドトーン(白基調·濃紺·建物写真·親しみやすさ)に寄せる
   ========================================================= */

:root {
  /* 信頼トーンに調整: 紺を深く、オレンジを落ち着いた銅色に */
  --brand-navy: #14304f;
  --brand-navy-deep: #091e3a;
  --brand-navy-soft: #2a4467;
  --brand-orange: #b08855;      /* ゴールド統一(CEOセクションと一致) */
  --brand-orange-deep: #826335;
  --brand-orange-bright: #e2c79a;
  --brand-warm-bg: #fbf8f2;     /* やや暖かみ */
  --brand-line: #e3dccd;        /* 線をやや薄く */
  --brand-line-strong: #c8bfa9;
  --brand-text: #1f2a40;        /* 本文を濃く */
  --brand-text-soft: #545d72;
  --brand-text-light: #8c94a4;
  --photo-overlay: linear-gradient(180deg, rgba(9, 30, 58, 0) 0%, rgba(9, 30, 58, 0.7) 100%);
  /* 余白系: より広い --sp- */
  --space-xxs: 4px;
  --space-xs: 8px;
  --space-sm: 16px;
  --space-md: 24px;
  --space-lg: 40px;
  --space-xl: 64px;
  --space-2xl: 96px;
  --space-3xl: 144px;
}

/* === ベース: フォント体系を「日本語サンセリフ主役」に === */
body {
  font-family: var(--sans);
  color: var(--brand-text);
  font-size: 15.5px;
  line-height: 1.95;
  letter-spacing: 0.03em;
  background: var(--white);
}
h1, h2, h3, h4, h5, h6 { color: var(--brand-navy-deep); letter-spacing: 0.02em; }

/* === HEADER: シンプル白 === */
.site-header {
  background: rgba(255, 255, 255, 0.97);
  border-bottom: 1px solid var(--brand-line);
  box-shadow: 0 1px 0 rgba(0,0,0,0.02);
  backdrop-filter: blur(16px);
}
.global-nav a { color: var(--brand-text); font-family: var(--sans); font-weight: 500; font-size: 14.5px; letter-spacing: 0.06em; }
.global-nav a:hover { color: var(--brand-orange); }
.logo-en { color: var(--brand-text-soft); }
.logo-jp { color: var(--brand-navy-deep); }

/* === HERO: 大型写真主役 + Smiling Tomorrow === */
.hero { min-height: 88vh; padding: 0; }
.hero::before {
  background-image:
    linear-gradient(95deg, rgba(15,35,66,0.85) 0%, rgba(15,35,66,0.5) 55%, rgba(15,35,66,0.2) 100%),
    url('../images/hero/fukuoka-momochi-aerial.jpg');
  background-size: cover;
  background-position: center 40%;
}
.hero::after { display: none; }
.hero-en {
  font-family: var(--sans);
  font-style: normal;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.32em;
  color: var(--brand-orange-bright);
}
.hero-en::before { background: var(--brand-orange-bright); width: 36px; }
.hero-h1 {
  font-family: "Shippori Mincho B1", "Noto Serif JP", serif;
  font-weight: 600;
  font-size: clamp(40px, 5.6vw, 78px);
  line-height: 1.42;
  letter-spacing: 0.04em;
  color: var(--gold-bright);
  text-shadow: 0 6px 30px rgba(0,0,0,0.55);
  margin-bottom: var(--sp-7);
  word-break: keep-all;
  overflow-wrap: anywhere;
  font-feature-settings: "palt" 1;
}
.hero-h1 br + em, .hero-h1 em + br { display: inline; }
.hero-h1 em {
  -webkit-text-fill-color: var(--brand-orange-bright);
  background: none;
  color: var(--brand-orange-bright);
  font-weight: 700;
}
.hero-h1 .accent {
  font-family: var(--sans);
  font-style: normal;
  font-weight: 500;
  font-size: 0.22em;
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.18em;
  margin-top: var(--sp-4);
}
.hero-sub {
  font-family: var(--sans);
  font-size: 15.5px;
  line-height: 2.15;
  color: rgba(255,255,255,0.92);
  letter-spacing: 0.06em;
  font-weight: 400;
  margin-top: var(--sp-6);
  font-feature-settings: "palt" 1;
}
.hero-sub strong { color: var(--brand-orange-bright); font-weight: 700; font-size: 1.05em; }
.hero-sub strong { color: var(--brand-orange-bright); font-weight: 700; }

/* HERO stat panel — 落ち着いた白パネル */
.hero-stats {
  background: rgba(255, 255, 255, 0.97);
  border: none;
  border-radius: 4px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.35);
  padding: var(--sp-7);
  backdrop-filter: blur(8px);
}
.hero-stats::before { display: none; }
.hero-stats-label {
  font-family: var(--sans);
  font-style: normal;
  font-weight: 700;
  font-size: 11px;
  color: var(--brand-orange);
  letter-spacing: 0.32em;
  border-bottom: 2px solid var(--brand-orange);
  padding-bottom: var(--sp-4);
  margin-bottom: var(--sp-5);
}
.hero-stat { border-bottom-color: var(--brand-line); padding: var(--sp-3) 0; }
.hero-stat-label { color: var(--brand-text-soft); font-family: var(--sans); font-weight: 500; font-size: 13px; letter-spacing: 0.08em; }
.hero-stat-value {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  -webkit-text-fill-color: var(--brand-navy-deep);
  background: none;
  color: var(--brand-navy-deep);
  font-size: 44px;
  letter-spacing: -0.02em;
}
.hero-stat-value small { -webkit-text-fill-color: var(--brand-text-soft); color: var(--brand-text-soft); font-family: var(--sans); font-size: 0.36em; font-weight: 500; }

.hero-cta-row { gap: var(--sp-4); margin-top: var(--sp-6); }
.hero-meta { color: rgba(255,255,255,0.75); font-family: var(--sans); }
.hero-meta span::before { color: var(--brand-orange-bright); }

/* === BUTTONS: 大きく、温かく === */
.btn {
  font-family: var(--sans);
  font-weight: 700;
  letter-spacing: 0.14em;
  border-radius: 2px;
  padding: 22px 44px;
  font-size: 15px;
  transition: all 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.btn-primary {
  background: var(--brand-orange);
  border: none;
  color: var(--white);
  box-shadow: 0 12px 32px rgba(226, 199, 154, 0.4), 0 2px 8px rgba(226, 199, 154, 0.2);
}
.btn-primary::after { display: none; }
.btn-primary:hover {
  background: var(--brand-orange-deep);
  transform: translateY(-3px);
  box-shadow: 0 18px 44px rgba(226, 199, 154, 0.5);
}
.btn-gold {
  background: var(--white);
  color: var(--brand-navy-deep);
  border: 2px solid var(--brand-navy-deep);
  font-weight: 700;
  box-shadow: 0 6px 20px rgba(15, 35, 66, 0.12);
}
.btn-gold:hover {
  background: var(--brand-navy-deep);
  color: var(--white);
  transform: translateY(-3px);
  box-shadow: 0 14px 36px rgba(15, 35, 66, 0.3);
}
.btn-outline { background: transparent; border: 2px solid var(--brand-navy-deep); color: var(--brand-navy-deep); }
.btn-outline:hover { background: var(--brand-navy-deep); color: var(--white); }
.btn-ghost { border-color: rgba(255,255,255,0.6); color: var(--white); }
.btn-ghost:hover { border-color: var(--brand-orange-bright); color: var(--brand-orange-bright); }
.btn-xl { padding: 26px 58px; font-size: 16px; }
.btn-lg { padding: 24px 50px; }

/* === SECTIONS: 白基調 === */
.section { padding: var(--sp-11) var(--sp-7); }
.section-light { background: var(--white); }
.section-cream { background: var(--brand-warm-bg); }
.section-warm { background: var(--white); }
.section-dark { background: var(--brand-navy-deep); }

.section-title {
  font-family: "Shippori Mincho B1", "Noto Serif JP", serif;
  font-weight: 600;
  font-size: clamp(30px, 3.8vw, 52px);
  line-height: 1.55;
  color: var(--brand-navy-deep);
  letter-spacing: 0.06em;
  font-feature-settings: "palt" 1;
}
.section-title em {
  background: linear-gradient(transparent 62%, rgba(226, 199, 154,0.2) 62%, rgba(226, 199, 154,0.2) 92%, transparent 92%);
  color: var(--brand-orange);
  font-weight: 700;
  border-bottom: none;
  padding: 0 6px;
}
.section-dark .section-title { color: var(--white); }
.section-dark .section-title em { background: linear-gradient(transparent 65%, rgba(232,132,86,0.3) 65%); color: var(--brand-orange-bright); }

.chapter-mark {
  font-family: var(--sans);
  font-style: normal;
  font-weight: 700;
  color: var(--brand-orange);
  font-size: 12px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
}
.chapter-mark::before, .chapter-mark::after { background: var(--brand-orange); width: 32px; }

.section-lead {
  font-family: var(--sans);
  font-size: 15.5px;
  color: var(--brand-text-soft);
  line-height: 2.1;
  letter-spacing: 0.06em;
  font-weight: 400;
  max-width: 720px;
  margin: var(--sp-6) auto 0;
  font-feature-settings: "palt" 1;
}
.section-dark .section-lead { color: rgba(255,255,255,0.82); }

/* === AUTHORITY BAR === */
.authority-section { background: var(--white); padding: var(--sp-8) var(--sp-7); border-top: none; border-bottom: 1px solid var(--brand-line); }
.authority-grid { border: none; padding: 0; gap: 0; }
.authority-item { padding: var(--sp-5) var(--sp-4); border-right: 1px solid var(--brand-line); }
.authority-item-name { color: var(--brand-navy-deep); font-family: var(--sans); font-weight: 700; font-size: 12.5px; letter-spacing: 0.04em; line-height: 1.7; }
.authority-item-en { color: var(--brand-orange); font-family: var(--sans); font-style: normal; font-weight: 600; letter-spacing: 0.18em; font-size: 10px; }
.authority-label { color: var(--brand-orange); font-family: var(--sans); font-style: normal; font-weight: 700; letter-spacing: 0.4em; }

/* === PERSONA CARDS: 写真ヘッダー付きカード === */
.persona-routing { background: var(--brand-warm-bg); }
.persona-grid { gap: var(--sp-6); }
.persona-card {
  padding: 0;
  background: var(--white);
  border: 1px solid var(--brand-line);
  box-shadow: 0 6px 24px rgba(15, 35, 66, 0.06);
  border-radius: 3px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.persona-card::before { display: none; }
.persona-card::after { display: none; }
.persona-card:hover { box-shadow: 0 24px 60px rgba(15, 35, 66, 0.16); border-color: var(--brand-orange); transform: translateY(-6px); }
.persona-card .persona-stage {
  background: var(--brand-navy-deep);
  color: var(--white);
  padding: var(--sp-5) var(--sp-7);
  font-family: var(--sans);
  font-style: normal;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.18em;
  margin: 0;
  position: relative;
}
.persona-card .persona-stage::after {
  content: "";
  position: absolute;
  bottom: 0; left: 0;
  width: 60px; height: 3px;
  background: var(--brand-orange);
}
.persona-stage-num {
  font-family: "Shippori Mincho B1", serif;
  font-size: 64px;
  font-weight: 600;
  -webkit-text-fill-color: var(--brand-orange);
  background: none;
  color: var(--brand-orange);
  text-align: left;
  padding: var(--sp-6) var(--sp-7) 0;
  margin: 0;
  line-height: 1;
}
.persona-title {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: 23px;
  line-height: 1.55;
  color: var(--brand-navy-deep);
  padding: var(--sp-3) var(--sp-7) var(--sp-5);
  margin: 0;
  border-bottom: 1px solid var(--brand-line);
  letter-spacing: 0.04em;
  font-feature-settings: "palt" 1;
}
.persona-title em { color: var(--brand-orange); font-weight: 700; font-style: normal; }
.persona-checklist { padding: var(--sp-6) var(--sp-7); margin: 0; }
.persona-checklist li { color: var(--brand-text); font-family: var(--sans); font-weight: 400; font-size: 13.5px; line-height: 2; padding: 4px 0 4px 24px; letter-spacing: 0.04em; }
.persona-checklist li::before { color: var(--brand-orange); content: "✓"; font-weight: 700; left: 0; top: 5px; font-size: 14px; }
.persona-recommend {
  margin: 0 var(--sp-7) var(--sp-5);
  background: var(--brand-warm-bg);
  border-left: 3px solid var(--brand-orange);
  padding: var(--sp-4) var(--sp-5);
}
.persona-recommend-label { color: var(--brand-orange); font-family: var(--sans); font-style: normal; font-weight: 700; letter-spacing: 0.32em; font-size: 10.5px; margin-bottom: 6px; text-transform: uppercase; }
.persona-recommend-text { color: var(--brand-navy-deep); font-family: var(--sans); font-weight: 700; font-size: 14px; line-height: 1.7; letter-spacing: 0.04em; }
.persona-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 0 var(--sp-7) var(--sp-7);
  background: var(--brand-orange);
  color: var(--white);
  padding: 18px;
  text-align: center;
  font-family: var(--sans);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.16em;
  border-bottom: none;
  align-self: stretch;
  border-radius: 2px;
  transition: all 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
  box-shadow: 0 8px 22px rgba(226, 199, 154,0.32);
}
.persona-cta::after { content: "→"; font-size: 16px; transition: transform 0.3s; }
.persona-cta:hover { background: var(--brand-orange-deep); color: var(--white); box-shadow: 0 14px 32px rgba(226, 199, 154,0.45); transform: translateY(-2px); }
.persona-cta:hover::after { transform: translateX(4px); }
.persona-card:hover .persona-cta { color: var(--white); border-bottom: none; }

/* === COMPARE TABLE === */
.compare-section { background: var(--brand-warm-bg); }
.compare-tbl { box-shadow: 0 16px 48px rgba(15, 35, 66, 0.08); border-radius: 3px; overflow: hidden; }
.compare-tbl thead th { font-family: var(--sans); font-weight: 700; }
.compare-tbl thead th.hilite { background: var(--brand-navy-deep); color: var(--white); }
.compare-tbl thead th.hilite::before { background: var(--brand-orange); height: 4px; }
.compare-tbl thead th.hilite small { color: var(--brand-orange-bright); font-family: var(--sans); font-style: normal; font-weight: 700; }
.compare-tbl thead th.muted small { color: var(--brand-text-light); font-family: var(--sans); font-style: normal; font-weight: 600; }
.compare-tbl tbody th { color: var(--brand-navy-deep); font-family: var(--sans); font-weight: 700; }
.compare-tbl tbody td { font-family: var(--sans); }
.compare-tbl tbody td.hilite-strong { background: rgba(226, 199, 154, 0.1); color: var(--brand-navy-deep); font-weight: 700; }

/* === BIG NUMBERS === */
.big-numbers-row { background: var(--white); box-shadow: 0 16px 60px rgba(15, 35, 66, 0.06); }
.big-numbers-row::before, .big-numbers-row::after { background: linear-gradient(90deg, transparent, var(--brand-orange), transparent); }
.big-number-en { color: var(--brand-orange); font-family: var(--sans); font-style: normal; font-weight: 700; }
.big-number-value {
  font-family: "Shippori Mincho B1", serif;
  -webkit-text-fill-color: var(--brand-navy-deep);
  background: none;
  color: var(--brand-navy-deep);
  font-weight: 600;
  font-size: clamp(56px, 6.8vw, 104px);
}
.big-number-label { color: var(--brand-text-soft); font-family: var(--sans); font-weight: 600; letter-spacing: 0.2em; }

/* === STRENGTH CARDS === */
.strength-card {
  background: var(--white);
  border: 1px solid var(--brand-line);
  border-radius: 3px;
  padding: var(--sp-8);
  box-shadow: 0 6px 24px rgba(15, 35, 66, 0.06);
}
.strength-card::before { background: var(--brand-orange); height: 3px; }
.strength-card::after { display: none; }
.strength-card:hover { border-color: var(--brand-orange); transform: translateY(-6px); box-shadow: 0 24px 60px rgba(15, 35, 66, 0.16); }
.strength-num { color: var(--brand-orange); font-family: var(--sans); font-style: normal; font-weight: 700; }
.strength-num strong {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  -webkit-text-fill-color: var(--brand-orange);
  background: none;
  color: var(--brand-orange);
}
.strength-title { color: var(--brand-navy-deep); font-family: "Shippori Mincho B1", serif; font-weight: 600; }
.strength-title em { color: var(--brand-orange); font-weight: 700; }
.strength-tag { background: var(--brand-warm-bg); color: var(--brand-orange-deep); border-color: var(--brand-line); font-family: var(--sans); font-weight: 600; }

/* === CONCERN ITEMS === */
.concern-item { background: var(--white); border-color: var(--brand-line); }
.concern-item:hover { border-color: var(--brand-orange); }
.concern-item::before { background: var(--brand-orange); }
.concern-num-en { color: var(--brand-orange); font-family: var(--sans); font-style: normal; font-weight: 700; letter-spacing: 0.32em; }
.concern-title { color: var(--brand-navy-deep); font-family: "Shippori Mincho B1", serif; font-weight: 600; }
.concern-body { color: var(--brand-text-soft); font-family: var(--sans); }

/* === PILLARS === */
.pillar-card { background: var(--white); border-color: var(--brand-line); }
.pillar-card:hover { border-color: var(--brand-orange); }
.pillar-num {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  -webkit-text-fill-color: var(--brand-orange);
  background: none;
  color: var(--brand-orange);
}
.pillar-title { color: var(--brand-navy-deep); font-family: "Shippori Mincho B1", serif; font-weight: 600; }
.pillar-count, .pillar-link { color: var(--brand-text-soft); font-family: var(--sans); }

/* === VOICES === */
.voice-card { background: var(--white); border-color: var(--brand-line); }
.voice-card:hover { border-color: var(--brand-orange); }
.voice-photo { background: linear-gradient(135deg, var(--brand-navy-soft), var(--brand-navy-deep)); border: 3px solid var(--brand-orange); }
.voice-quote { color: var(--brand-navy-deep); font-family: "Shippori Mincho B1", serif; font-weight: 600; }
.voice-tag { color: var(--brand-orange); font-family: var(--sans); font-weight: 700; letter-spacing: 0.2em; }

/* === MATERIAL BANNER === */
.material-banner { padding: var(--sp-11) var(--sp-7); }
.material-banner::before {
  background-image:
    linear-gradient(95deg, rgba(15,35,66,0.93) 30%, rgba(15,35,66,0.55) 100%),
    url('../images/hero/fukuoka-night.jpg');
  background-size: cover;
  background-position: center;
}
.material-banner-en { color: var(--brand-orange-bright); font-family: var(--sans); font-style: normal; font-weight: 700; }
.material-banner h2 { font-family: "Shippori Mincho B1", serif; font-weight: 600; }
.material-banner h2 em { color: var(--brand-orange-bright); font-weight: 700; }
.material-banner-features li { font-family: var(--sans); }
.material-banner-features li::before { color: var(--brand-orange-bright); content: "✓"; font-size: 13px; top: 5px; }

/* === FINAL CTA === */
.final-cta {
  background: linear-gradient(105deg, var(--brand-navy-deep) 0%, var(--brand-navy) 100%);
  position: relative;
}
.final-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(15,35,66,0.88), rgba(15,35,66,0.94)),
    url('../images/hero/fukuoka-night.jpg');
  background-size: cover;
  background-position: center;
  opacity: 0.6;
}
.final-cta-inner { position: relative; z-index: 1; }
.final-cta-en { color: var(--brand-orange-bright); font-family: var(--sans); font-style: normal; font-weight: 700; letter-spacing: 0.4em; }
.final-cta h2 { font-family: "Shippori Mincho B1", serif; font-weight: 600; color: var(--white); }
.final-cta h2 em { color: var(--brand-orange-bright); font-weight: 700; -webkit-text-fill-color: var(--brand-orange-bright); background: none; }
.final-cta p { font-family: var(--sans); color: rgba(255,255,255,0.88); }
.final-cta-phone strong { color: var(--brand-orange-bright); font-family: "Shippori Mincho B1", serif; }

/* === STICKY CTA === */
.sticky-cta { background: var(--brand-navy-deep); border-top: 3px solid var(--brand-orange); }
.sticky-cta::before { background: var(--brand-orange); }
.sticky-cta-text strong { color: var(--brand-orange-bright); font-family: var(--sans); font-weight: 700; }
.sticky-cta-text small { color: var(--brand-orange-bright); font-family: var(--sans); font-style: normal; font-weight: 600; }
.sticky-cta-btn { font-family: var(--sans); font-weight: 600; border: 1px solid rgba(255,255,255,0.4); border-radius: 2px; }
.sticky-cta-btn.primary { background: var(--brand-orange); color: var(--white); border-color: var(--brand-orange); }
.sticky-cta-btn.primary:hover { background: var(--brand-orange-deep); }
.sticky-cta-btn:hover { background: var(--white); color: var(--brand-navy-deep); }

/* === PAGE HERO (sub-pages) === */
.page-hero {
  background: linear-gradient(95deg, var(--brand-navy-deep) 30%, var(--brand-navy) 100%);
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(95deg, rgba(9,30,58,0.82), rgba(9,30,58,0.5)),
    url('../images/hero/fukuoka-tenjin-crossing.jpg');
  background-size: cover;
  background-position: center;
}
.page-hero-inner { position: relative; z-index: 1; }
.page-hero h1 {
  font-family: "Shippori Mincho B1", serif !important;
  color: var(--white) !important;
  font-weight: 600;
}
.page-hero h1 em { -webkit-text-fill-color: var(--brand-orange-bright); background: none; color: var(--brand-orange-bright); font-weight: 700; }
.page-hero-en { color: var(--brand-orange-bright); font-family: var(--sans); font-style: normal; font-weight: 700; }
.page-hero-lead { color: rgba(255,255,255,0.88); font-family: var(--sans); }

/* === BREADCRUMB === */
.breadcrumb { background: var(--white); border-bottom: 1px solid var(--brand-line); }
.breadcrumb a { color: var(--brand-text-soft); font-family: var(--sans); }
.breadcrumb a:hover { color: var(--brand-orange); }

/* === FOOTER === */
.site-footer { background: var(--brand-navy-deep); }
.footer-inner h4, .footer-col h4 { color: var(--brand-orange-bright); font-family: var(--sans); font-weight: 700; letter-spacing: 0.2em; }
.footer-col a, .footer-addr, .footer-phone { font-family: var(--sans); }
.footer-logo-en { color: var(--brand-orange-bright); }

/* === Top bar === */
.top-bar { background: var(--brand-navy-deep); color: rgba(255,255,255,0.85); font-family: var(--sans); font-size: 11.5px; letter-spacing: 0.1em; }
.top-bar em { color: var(--brand-orange-bright); }

/* === LINE === */
.line-fixed { font-family: var(--sans); font-weight: 700; }

/* === Page hero typography fix === */
.page-hero h1 { font-size: clamp(40px, 5.4vw, 78px) !important; line-height: 1.32 !important; }

/* ===========================================================
   TRUST POLISH v4 — 全体を「信頼されるデザイン」に整える
   =========================================================== */

/* === HEADER: 上品で薄い ============================================ */
.site-header {
  background: rgba(255,255,255,0.96);
  border-bottom: 1px solid rgba(20,48,79,0.06);
  box-shadow: none;
}
.site-header.is-scrolled {
  background: rgba(255,255,255,0.98);
  border-bottom-color: rgba(20,48,79,0.08);
  box-shadow: 0 1px 0 rgba(20,48,79,0.04), 0 8px 28px rgba(20,48,79,0.06);
}
.header-inner { padding: 18px var(--sp-7); }
.global-nav { gap: var(--sp-7); }
.global-nav a { font-size: 13.5px; font-weight: 500; letter-spacing: 0.08em; color: var(--brand-text); position: relative; padding: 6px 0; }
.global-nav a::after { content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 1px; background: var(--brand-orange); transform: scaleX(0); transform-origin: center; transition: transform 0.3s; }
.global-nav a:hover::after { transform: scaleX(1); }
.global-nav a:hover { color: var(--brand-navy-deep); }

.logo-en { font-size: 11px; letter-spacing: 0.18em; font-weight: 500; color: var(--brand-text-soft); margin-bottom: 2px; }
.logo-jp { font-family: "Shippori Mincho B1", serif; font-size: 17px; letter-spacing: 0.04em; font-weight: 600; color: var(--brand-navy-deep); }

.header-phone-label { font-family: var(--sans); font-style: normal; font-weight: 700; font-size: 9.5px; color: var(--brand-orange); letter-spacing: 0.3em; text-transform: uppercase; margin-bottom: 2px; }
.header-phone-num { font-family: "Shippori Mincho B1", serif; font-size: 18px; font-weight: 600; color: var(--brand-navy-deep); letter-spacing: 0.05em; font-variant-numeric: tabular-nums; }
.header-phone-num:hover { color: var(--brand-orange); }

/* === TOP BAR: 細く繊細に ============================================ */
.top-bar { padding: 9px var(--sp-7); font-size: 11px; letter-spacing: 0.12em; background: var(--brand-navy-deep); color: rgba(255,255,255,0.78); }
.top-bar em { color: var(--brand-orange-bright); }

/* === HERO: 信頼感と落ち着きを強化 ===================================== */
.hero { min-height: 92vh; }
.hero::before {
  background-image:
    linear-gradient(98deg, rgba(9,30,58,0.85) 0%, rgba(9,30,58,0.5) 55%, rgba(9,30,58,0.18) 100%),
    url('../images/hero/fukuoka-skyline.jpg') !important;
  background-size: cover !important;
  background-position: center !important;
}
.hero-en {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.45em;
  color: var(--brand-orange-bright);
  margin-bottom: var(--sp-7);
  text-transform: uppercase;
}
.hero-en::before { background: var(--brand-orange-bright); width: 40px; }
.hero-h1 { font-weight: 600 !important; letter-spacing: 0.04em !important; }
.hero-h1 em {
  color: var(--brand-orange-bright);
  font-weight: 700;
  -webkit-text-fill-color: var(--brand-orange-bright);
  background: none;
}
.hero-h1 .accent {
  font-family: var(--sans);
  font-style: normal;
  font-weight: 600;
  font-size: 0.18em;
  color: rgba(255,255,255,0.78);
  letter-spacing: 0.32em;
  margin-top: var(--sp-6);
  text-transform: uppercase;
}

.hero-stats {
  background: rgba(255,255,255,0.97);
  box-shadow: 0 40px 100px rgba(9,30,58,0.4), 0 1px 0 rgba(255,255,255,0.5) inset;
  padding: var(--sp-8) var(--sp-7);
  border-radius: 2px;
}
.hero-stats-label { font-weight: 700; font-size: 10.5px; letter-spacing: 0.4em; color: var(--brand-orange); border-bottom: 1px solid rgba(20,48,79,0.1); padding-bottom: var(--sp-4); margin-bottom: var(--sp-6); text-transform: uppercase; }
.hero-stat { padding: 14px 0; border-bottom: 1px solid rgba(20,48,79,0.08); }
.hero-stat-label { font-size: 12px; font-weight: 500; color: var(--brand-text-soft); letter-spacing: 0.12em; }
.hero-stat-value { font-size: 38px; color: var(--brand-navy-deep); -webkit-text-fill-color: var(--brand-navy-deep); background: none; font-weight: 600; letter-spacing: -0.02em; }
.hero-stat-value small { font-size: 0.34em; color: var(--brand-text-soft); -webkit-text-fill-color: var(--brand-text-soft); margin-left: 4px; font-weight: 500; }

.scarcity-badge {
  margin-bottom: var(--sp-5);
  padding: 7px 14px;
  font-size: 11px;
  letter-spacing: 0.1em;
  font-weight: 700;
}
.scarcity-badge.in-hero {
  background: rgba(255,255,255,0.08);
  border-color: rgba(210,125,79,0.5);
  color: var(--brand-orange-bright);
}

.hero-meta {
  margin-top: var(--sp-6);
  font-size: 11px;
  letter-spacing: 0.22em;
  color: rgba(255,255,255,0.62);
  font-weight: 500;
}
.hero-meta span { margin-right: var(--sp-6); }
.hero-meta span::before { content: "—"; color: var(--brand-orange-bright); margin-right: 6px; }

/* === BUTTONS: 落ち着き ========================================== */
.btn { font-weight: 700; letter-spacing: 0.16em; padding: 20px 40px; font-size: 13.5px; border-radius: 2px; }
.btn-primary {
  background: var(--brand-orange);
  box-shadow: 0 10px 28px rgba(176, 136, 85,0.32), 0 1px 0 rgba(255,255,255,0.18) inset;
}
.btn-primary:hover { background: var(--brand-orange-deep); transform: translateY(-2px); box-shadow: 0 16px 36px rgba(176, 136, 85,0.42); }
.btn-gold {
  background: rgba(255,255,255,0.08);
  color: var(--white);
  border: 1px solid rgba(255,255,255,0.4);
  box-shadow: none;
  backdrop-filter: blur(8px);
}
.btn-gold:hover { background: var(--white); color: var(--brand-navy-deep); border-color: var(--white); transform: translateY(-2px); }
.btn-outline { background: transparent; border: 1px solid var(--brand-navy-deep); color: var(--brand-navy-deep); box-shadow: none; }
.btn-outline:hover { background: var(--brand-navy-deep); color: var(--white); transform: translateY(-2px); box-shadow: 0 14px 36px rgba(9,30,58,0.32); }
.btn-xl { padding: 24px 56px; font-size: 14.5px; letter-spacing: 0.18em; }
.btn-lg { padding: 22px 48px; }

/* === SECTION HEADS: より上品 ====================================== */
.chapter-mark {
  font-size: 11px;
  letter-spacing: 0.4em;
  font-weight: 700;
  color: var(--brand-orange);
  text-transform: uppercase;
  margin-bottom: var(--sp-5);
}
.chapter-mark::before, .chapter-mark::after { width: 30px; background: var(--brand-orange); }

.section-title { font-weight: 600; line-height: 1.6 !important; letter-spacing: 0.06em !important; color: var(--brand-navy-deep); }
.section-title em {
  background: linear-gradient(transparent 64%, rgba(176, 136, 85,0.18) 64%, rgba(176, 136, 85,0.18) 92%, transparent 92%);
  color: var(--brand-orange);
  font-weight: 700;
  padding: 0 4px;
  font-style: normal;
}

.section-lead {
  font-weight: 400;
  font-size: 15px;
  line-height: 2.1;
  letter-spacing: 0.06em;
  color: var(--brand-text-soft);
  margin-top: var(--sp-5);
}

/* === USP TRIANGLE: refined ====================================== */
.usp-card { padding: var(--sp-9) var(--sp-7); border-radius: 3px; box-shadow: 0 6px 20px rgba(9,30,58,0.04); }
.usp-card.highlight {
  background: linear-gradient(180deg, var(--brand-navy-deep) 0%, var(--brand-navy) 100%);
  box-shadow: 0 32px 80px rgba(9,30,58,0.3);
  border: none;
}
.usp-card:hover { box-shadow: 0 24px 56px rgba(9,30,58,0.12); border-color: rgba(176, 136, 85,0.5); }
.usp-icon { font-size: 52px; line-height: 1; color: var(--brand-orange); font-weight: 600; letter-spacing: -0.04em; }
.usp-card.highlight .usp-icon { color: var(--brand-orange-bright); }
.usp-axis { font-size: 10.5px; letter-spacing: 0.36em; }
.usp-h { font-size: 22px !important; line-height: 1.65 !important; letter-spacing: 0.05em !important; }
.usp-p { font-size: 13.5px; line-height: 2.05; letter-spacing: 0.05em; }
.usp-list li { font-size: 12.5px; line-height: 2.1; letter-spacing: 0.04em; }

/* === CEO TRUST: photo enhance =================================== */
.ceo-trust { background: linear-gradient(180deg, var(--white) 0%, var(--brand-warm-bg) 100%); }
.ceo-trust-photo { filter: contrast(1.05) saturate(1.05); border-radius: 2px; }
.ceo-trust-frame { border-color: rgba(176, 136, 85,0.6); }
.ceo-trust-caption { box-shadow: 0 24px 56px rgba(9,30,58,0.18); border-left-color: var(--brand-orange); border-radius: 2px; }
.ceo-trust-name-en { color: var(--brand-orange); font-size: 12px; letter-spacing: 0.22em; font-weight: 600; }
.ceo-trust-name-jp { font-size: 18px; }
.ceo-trust-tag { font-size: 11px; letter-spacing: 0.4em; font-weight: 700; }
.ceo-trust-h { font-weight: 600; line-height: 1.6 !important; letter-spacing: 0.05em !important; }
.ceo-trust-h em {
  background: linear-gradient(transparent 64%, rgba(176, 136, 85,0.2) 64%, rgba(176, 136, 85,0.2) 92%, transparent 92%);
  color: var(--brand-orange);
  font-weight: 700;
}
.ceo-trust-creds { background: var(--white); border: 1px solid var(--brand-line); border-left: 3px solid var(--brand-orange); border-radius: 2px; }
.ceo-trust-creds-label { font-size: 10.5px; letter-spacing: 0.36em; font-weight: 700; color: var(--brand-orange); text-transform: uppercase; }
.ceo-trust-creds li { font-size: 12.5px; line-height: 1.95; letter-spacing: 0.04em; }
.ceo-trust-creds li::before { color: var(--brand-orange); }

/* === FREE TOOLS: card refinement ================================= */
.tool-card { padding: var(--sp-8) var(--sp-7); border-radius: 3px; box-shadow: 0 4px 16px rgba(9,30,58,0.04); }
.tool-card:hover { box-shadow: 0 24px 56px rgba(9,30,58,0.12); border-color: rgba(176, 136, 85,0.6); }
.tool-badge { font-size: 10.5px; letter-spacing: 0.2em; padding: 5px 11px; border-radius: 2px; font-weight: 700; }
.tool-h { font-size: 19px !important; line-height: 1.65 !important; letter-spacing: 0.05em !important; }
.tool-p { font-size: 13px; line-height: 2.05; letter-spacing: 0.05em; }
.tool-meta span { font-size: 11px; padding: 4px 9px; border-radius: 2px; }
.tool-cta { font-size: 12.5px; letter-spacing: 0.12em; }

/* === WHY FUKUOKA: data card refinement =========================== */
.fukuoka-data-card { padding: var(--sp-8) var(--sp-7); border-radius: 3px; box-shadow: 0 4px 16px rgba(9,30,58,0.04); border-top-width: 2px; }
.fukuoka-data-card:hover { box-shadow: 0 24px 56px rgba(9,30,58,0.12); }
.fukuoka-data-en { font-size: 10.5px; letter-spacing: 0.36em; font-weight: 700; }
.fukuoka-data-num { font-weight: 600; line-height: 1; letter-spacing: -0.03em; }
.fukuoka-data-title { font-size: 15.5px; line-height: 1.6; letter-spacing: 0.04em; padding-bottom: var(--sp-4); margin-bottom: var(--sp-4); }
.fukuoka-data-desc { font-size: 12.5px; line-height: 2; letter-spacing: 0.05em; }

/* === WARD MAP: refinement ====================================== */
.ward-card { border-radius: 3px; padding: var(--sp-7) var(--sp-3); transition: all 0.4s; }
.ward-name { font-size: 18px; }
.ward-en { font-size: 11px; }
.ward-attr { font-size: 11px; padding-top: var(--sp-3); }

/* === BIG NUMBERS: refinement ==================================== */
.big-numbers-row { background: var(--white); }
.big-number { padding: var(--sp-9) var(--sp-5); }
.big-number-en { font-size: 10.5px; letter-spacing: 0.4em; font-weight: 700; }
.big-number-value { font-weight: 600; letter-spacing: -0.03em; -webkit-text-fill-color: var(--brand-navy-deep); background: none; color: var(--brand-navy-deep); }
.big-number-label { font-size: 12px; letter-spacing: 0.22em; font-weight: 600; color: var(--brand-text-soft); }

/* === STRENGTHS CARDS: refinement ================================= */
.strength-card { padding: var(--sp-9) var(--sp-7); border-radius: 3px; box-shadow: 0 4px 16px rgba(9,30,58,0.04); }
.strength-card:hover { box-shadow: 0 24px 56px rgba(9,30,58,0.12); }
.strength-num { font-size: 11.5px; letter-spacing: 0.36em; font-weight: 700; color: var(--brand-orange); }
.strength-num strong { font-size: 64px; font-weight: 600; letter-spacing: -0.04em; }
.strength-title { font-size: 21px; line-height: 1.65; letter-spacing: 0.05em; }
.strength-body { font-size: 13.5px; line-height: 2.05; letter-spacing: 0.05em; }
.strength-tag { font-size: 11px; padding: 4px 10px; }

/* === CONCERNS: refinement ====================================== */
.concern-item { padding: var(--sp-7) var(--sp-7); border-radius: 0; }
.concern-num-en { font-size: 11px; letter-spacing: 0.36em; font-weight: 700; }
.concern-title { font-size: 19px; line-height: 1.65; letter-spacing: 0.04em; margin-bottom: var(--sp-4); }
.concern-body { font-size: 13px; line-height: 2.05; letter-spacing: 0.05em; }

/* === PROCESS SECTION: refinement ============================ */
.process-step { padding: var(--sp-7) var(--sp-7); border-radius: 3px; box-shadow: 0 4px 14px rgba(9,30,58,0.04); }
.process-step:hover { box-shadow: 0 18px 44px rgba(9,30,58,0.12); }
.process-num { font-size: 64px; color: rgba(176, 136, 85,0.08); font-weight: 600; letter-spacing: -0.04em; }
.process-time { font-size: 10.5px; letter-spacing: 0.32em; font-weight: 700; }
.process-step h4 { font-size: 20px; line-height: 1.6; letter-spacing: 0.05em; }
.process-step p { font-size: 13.5px; line-height: 2.05; letter-spacing: 0.05em; }

/* === FAQ: refinement ============================================ */
.faq-item { border-radius: 3px; box-shadow: 0 2px 10px rgba(9,30,58,0.03); }
.faq-item summary { font-size: 15.5px; line-height: 1.65; letter-spacing: 0.04em; padding: var(--sp-5) var(--sp-7); padding-right: 64px; }
.faq-body { font-size: 13.5px; line-height: 2.05; letter-spacing: 0.05em; }

/* === MATERIAL BANNER: refinement ================================== */
.material-banner-en { font-size: 11.5px; letter-spacing: 0.4em; font-weight: 700; }
.material-banner h2 { font-weight: 600; letter-spacing: 0.05em; line-height: 1.55; }

/* === FINAL CTA: refinement ===================================== */
.final-cta-en { font-size: 11px; letter-spacing: 0.4em; font-weight: 700; }
.final-cta h2 { font-weight: 600; letter-spacing: 0.05em; line-height: 1.55; }

/* === FOOTER: 信頼に充実な情報 ==================================== */
.site-footer { background: var(--brand-navy-deep); padding-top: var(--sp-11); padding-bottom: var(--sp-7); }
.footer-inner { padding: 0 var(--sp-7); gap: var(--sp-9); }
.footer-logo-en { color: var(--brand-orange-bright); font-size: 14px; letter-spacing: 0.18em; font-weight: 600; margin-bottom: 6px; }
.footer-logo-jp { color: var(--white); font-family: "Shippori Mincho B1", serif; font-size: 19px; letter-spacing: 0.04em; font-weight: 600; margin-bottom: var(--sp-5); }
.footer-addr { color: rgba(255,255,255,0.72); font-size: 12.5px; line-height: 1.95; letter-spacing: 0.06em; margin-bottom: var(--sp-4); }
.footer-phone { color: var(--brand-orange-bright); font-family: "Shippori Mincho B1", serif; font-size: 22px; letter-spacing: 0.05em; font-weight: 600; margin-top: var(--sp-3); }
.footer-col h4 { color: var(--brand-orange-bright); font-size: 11px; letter-spacing: 0.3em; font-weight: 700; margin-bottom: var(--sp-4); text-transform: uppercase; }
.footer-col a { color: rgba(255,255,255,0.78); font-size: 13px; letter-spacing: 0.06em; padding: 6px 0; display: block; transition: color 0.2s, padding 0.2s; }
.footer-col a:hover { color: var(--brand-orange-bright); padding-left: 4px; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.1); padding-top: var(--sp-6); margin-top: var(--sp-9); font-size: 11.5px; letter-spacing: 0.06em; color: rgba(255,255,255,0.5); }

/* === BREADCRUMB: 上品 =========================================== */
.breadcrumb { background: var(--brand-warm-bg); padding: 12px 0; border-bottom: 1px solid var(--brand-line); }
.breadcrumb a, .breadcrumb { font-size: 11.5px; letter-spacing: 0.06em; color: var(--brand-text-soft); }

/* === STICKY CTA refinement ====================================== */
.sticky-cta {
  background: rgba(9,30,58,0.96);
  backdrop-filter: blur(20px);
  border-top: 1px solid rgba(176, 136, 85,0.5);
  padding: var(--sp-3) var(--sp-7);
  box-shadow: 0 -16px 48px rgba(9,30,58,0.25);
}
.sticky-cta::before {
  background: linear-gradient(90deg, transparent, var(--brand-orange-bright), transparent);
  height: 1px;
}
.sticky-cta-text { font-size: 12.5px; letter-spacing: 0.06em; }
.sticky-cta-text strong { color: var(--brand-orange-bright); font-weight: 700; }
.sticky-cta-text small { font-size: 9.5px; letter-spacing: 0.32em; color: var(--brand-orange-bright); }
.sticky-cta-btn { padding: 10px 22px; font-size: 12px; letter-spacing: 0.14em; font-weight: 700; border-radius: 2px; }
.sticky-cta-btn.primary { background: var(--brand-orange); border-color: var(--brand-orange); }
.sticky-cta-btn.primary:hover { background: var(--brand-orange-deep); border-color: var(--brand-orange-deep); }

/* === Authority bar refinement ==================================== */
.authority-section { padding: var(--sp-9) var(--sp-7); border-top: none; }
.authority-label { font-size: 11px; letter-spacing: 0.4em; font-weight: 700; }
.authority-grid { padding: var(--sp-7) 0; border-top: 1px solid var(--brand-line); border-bottom: 1px solid var(--brand-line); }
.authority-item-name { font-size: 12.5px; line-height: 1.7; letter-spacing: 0.05em; font-weight: 700; }
.authority-item-en { font-size: 9.5px; letter-spacing: 0.3em; font-weight: 700; text-transform: uppercase; }

/* === Trust pulse refinement ======================================= */
.trust-pulse {
  background: var(--white);
  border: 1px solid var(--brand-line);
  border-radius: 100px;
  padding: 9px 16px 9px 11px;
  box-shadow: 0 16px 40px rgba(9,30,58,0.12);
  font-size: 12px;
}

/* === Voice cards refinement ====================================== */
.voice-card { border-radius: 3px; box-shadow: 0 4px 14px rgba(9,30,58,0.04); }
.voice-card:hover { box-shadow: 0 24px 56px rgba(9,30,58,0.12); }

/* === Pillar cards refinement ===================================== */
.pillar-card { border-radius: 3px; box-shadow: 0 4px 14px rgba(9,30,58,0.04); padding: var(--sp-9) var(--sp-7); }
.pillar-card:hover { box-shadow: 0 24px 56px rgba(9,30,58,0.12); }

/* === Mobile FAB refinement ====================================== */
.fab { box-shadow: 0 12px 32px rgba(9,30,58,0.32); }
.fab:hover { box-shadow: 0 18px 48px rgba(9,30,58,0.42); }

/* === Selection color ============================================ */
::selection { background: var(--brand-orange); color: var(--white); }

/* === CONCERN: アイコン+結果バッジで視覚化 ============================ */
.concerns-grid { gap: 0; }
.concern-item {
  position: relative;
  padding: var(--sp-8) var(--sp-7) var(--sp-7);
}
.concern-icon {
  width: 48px;
  height: 48px;
  margin-bottom: var(--sp-5);
  color: var(--brand-orange);
  opacity: 0.92;
}
.concern-icon svg { width: 100%; height: 100%; }
.concern-result {
  margin-top: var(--sp-5);
  padding: 10px 14px;
  background: var(--brand-warm-bg);
  border-left: 3px solid var(--brand-orange);
  font-family: var(--sans);
  font-size: 12.5px;
  letter-spacing: 0.06em;
  color: var(--brand-text-soft);
  border-radius: 2px;
}
.concern-result strong {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  color: var(--brand-orange-deep);
  font-size: 14.5px;
  margin-right: 4px;
}
.concern-body { display: none; } /* 旧本文を非表示に */

/* === CEO COMPARE TABLE: 大手 vs アスパートナー =================== */
.ceo-compare {
  width: 100%;
  border-collapse: collapse;
  margin-top: var(--sp-6);
  margin-bottom: var(--sp-7);
  background: var(--white);
  border: 1px solid var(--brand-line);
  border-radius: 3px;
  overflow: hidden;
  font-family: var(--sans);
}
.ceo-compare thead th {
  padding: 14px 12px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-align: center;
  background: var(--brand-warm-bg);
  border-bottom: 1px solid var(--brand-line);
}
.ceo-compare thead th.ceo-compare-other { color: var(--brand-text-light); font-weight: 500; }
.ceo-compare thead th.ceo-compare-self {
  background: var(--brand-orange);
  color: var(--white);
  position: relative;
}
.ceo-compare thead th.ceo-compare-self::after {
  content: "";
  position: absolute;
  top: 100%; left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: var(--brand-orange);
}
.ceo-compare tbody th {
  padding: 14px 16px;
  text-align: left;
  font-size: 12.5px;
  font-weight: 700;
  color: var(--brand-navy-deep);
  background: var(--brand-warm-bg);
  border-bottom: 1px solid var(--brand-line);
  letter-spacing: 0.04em;
  width: 28%;
}
.ceo-compare tbody td {
  padding: 14px 12px;
  font-size: 12.5px;
  color: var(--brand-text-soft);
  text-align: center;
  border-bottom: 1px solid var(--brand-line);
  border-left: 1px solid var(--brand-line);
  letter-spacing: 0.04em;
  line-height: 1.6;
}
.ceo-compare tbody td:last-child {
  background: rgba(176, 136, 85,0.05);
  color: var(--brand-navy-deep);
}
.ceo-compare tbody td strong {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  color: var(--brand-orange-deep);
  font-size: 13.5px;
}
.ceo-compare tbody tr:last-child th, .ceo-compare tbody tr:last-child td { border-bottom: none; }

/* === YIELD COMPARISON CHART ===================================== */
.yield-chart-section {
  background: var(--white);
  padding: var(--sp-9) var(--sp-7);
  border-radius: 4px;
  box-shadow: 0 6px 24px rgba(9,30,58,0.06);
  margin: var(--sp-9) auto;
  max-width: 920px;
  border: 1px solid var(--brand-line);
}
.yield-chart-head { text-align: center; margin-bottom: var(--sp-7); }
.yield-chart-tag {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 11px;
  color: var(--brand-orange);
  letter-spacing: 0.4em;
  margin-bottom: var(--sp-3);
  text-transform: uppercase;
}
.yield-chart-h {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: clamp(20px, 2.6vw, 28px);
  color: var(--brand-navy-deep);
  letter-spacing: 0.05em;
  line-height: 1.6;
  margin-bottom: var(--sp-3);
}
.yield-chart-h em {
  color: var(--brand-orange);
  font-style: normal;
  font-weight: 700;
  background: linear-gradient(transparent 64%, rgba(176, 136, 85,0.18) 64%, rgba(176, 136, 85,0.18) 92%, transparent 92%);
  padding: 0 4px;
}
.yield-chart-p {
  font-family: var(--sans);
  font-size: 11.5px;
  color: var(--brand-text-light);
  letter-spacing: 0.06em;
}

.yield-chart {
  display: grid;
  gap: var(--sp-4);
  margin: 0 auto;
}
.yield-row {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: var(--sp-4);
  align-items: center;
}
.yield-label {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: 15px;
  color: var(--brand-navy-deep);
  letter-spacing: 0.06em;
  text-align: right;
}
.yield-bar-wrap {
  background: var(--brand-warm-bg);
  border-radius: 2px;
  height: 38px;
  position: relative;
  overflow: hidden;
}
.yield-bar {
  height: 100%;
  width: var(--w, 60%);
  background: linear-gradient(90deg, var(--brand-text-light) 0%, var(--brand-text-soft) 100%);
  display: flex;
  align-items: center;
  padding: 0 var(--sp-4);
  border-radius: 2px;
  transform-origin: left;
  animation: yield-grow 1.4s cubic-bezier(0.22,0.61,0.36,1);
}
.yield-bar.yield-fukuoka {
  background: linear-gradient(90deg, var(--brand-orange) 0%, var(--brand-orange-deep) 100%);
  box-shadow: 0 4px 16px rgba(176, 136, 85,0.32);
}
@keyframes yield-grow {
  from { width: 0; }
  to { width: var(--w, 60%); }
}
.yield-val {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: 14px;
  color: var(--white);
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
}
.yield-chart-note {
  margin-top: var(--sp-7);
  padding-top: var(--sp-6);
  border-top: 1px dashed var(--brand-line);
  font-family: var(--sans);
  font-size: 13.5px;
  line-height: 2;
  color: var(--brand-text-soft);
  text-align: center;
  letter-spacing: 0.05em;
}
.yield-chart-note strong {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  color: var(--brand-orange-deep);
  font-size: 16px;
}
@media (max-width: 640px) {
  .yield-row { grid-template-columns: 70px 1fr; gap: var(--sp-3); }
  .yield-label { font-size: 13px; }
  .yield-val { font-size: 12px; }
}

/* ===========================================================
   SPACING TIGHTEN v5 — 余白を詰める
   =========================================================== */
.section, .usp-triangle, .free-tools, .ceo-trust, .persona-routing,
.compare-section, .material-banner, .final-cta, .why-fukuoka,
.process-section, .faq-section {
  padding-top: clamp(64px, 6.5vw, 104px) !important;
  padding-bottom: clamp(64px, 6.5vw, 104px) !important;
}
.authority-section { padding-top: var(--sp-7) !important; padding-bottom: var(--sp-7) !important; }

.section-head { margin-bottom: clamp(40px, 4.5vw, 72px) !important; }

.section-title + .section-lead,
.usp-title + .section-lead,
.material-banner h2 + p,
.final-cta h2 + p { margin-top: clamp(12px, 1.5vw, 22px) !important; }

.usp-grid { gap: var(--sp-5) !important; }
.tools-grid { gap: var(--sp-4) !important; }
.persona-grid { gap: var(--sp-5) !important; }
.fukuoka-data-grid { gap: var(--sp-4) !important; }
.strengths-grid { gap: var(--sp-5) !important; }
.concerns-grid { gap: 0 !important; }

/* カード内パディングも詰める */
.usp-card { padding: var(--sp-7) var(--sp-6) !important; }
.tool-card { padding: var(--sp-6) var(--sp-6) !important; }
.persona-card .persona-stage { padding: var(--sp-4) var(--sp-6) !important; }
.persona-stage-num { padding: var(--sp-5) var(--sp-6) 0 !important; font-size: 56px !important; }
.persona-title { padding: var(--sp-3) var(--sp-6) var(--sp-4) !important; font-size: 21px !important; }
.persona-checklist { padding: var(--sp-5) var(--sp-6) !important; }
.persona-recommend { margin: 0 var(--sp-6) var(--sp-4) !important; padding: var(--sp-3) var(--sp-4) !important; }
.persona-cta { margin: 0 var(--sp-6) var(--sp-6) !important; padding: 16px !important; }
.fukuoka-data-card { padding: var(--sp-7) var(--sp-6) !important; }
.strength-card { padding: var(--sp-7) var(--sp-6) !important; }
.concern-item { padding: var(--sp-7) var(--sp-6) var(--sp-6) !important; }
.process-step { padding: var(--sp-5) var(--sp-6) !important; margin-bottom: var(--sp-4) !important; }
.faq-item summary { padding: var(--sp-4) var(--sp-6) !important; padding-right: 56px !important; }
.faq-body { padding: var(--sp-3) var(--sp-6) var(--sp-5) !important; }

.ward-map-section { padding-top: var(--sp-7) !important; }
.ward-map-head { margin-bottom: var(--sp-6) !important; }
.yield-chart-section { margin: var(--sp-7) auto !important; padding: var(--sp-7) var(--sp-6) !important; }
.yield-chart-head { margin-bottom: var(--sp-5) !important; }

.ceo-trust-creds { margin: var(--sp-5) 0 !important; padding: var(--sp-5) !important; }
.ceo-trust-cta-row { margin-top: var(--sp-5) !important; }
.ceo-compare { margin-top: var(--sp-4) !important; margin-bottom: var(--sp-5) !important; }
.ceo-compare thead th, .ceo-compare tbody th, .ceo-compare tbody td { padding: 12px !important; }

/* Hero 内側余白も詰める */
.hero-inner { gap: var(--sp-7) !important; }
.hero-stats { padding: var(--sp-6) var(--sp-6) !important; }
.scarcity-badge { margin-bottom: var(--sp-4) !important; }
.hero-h1 { margin-bottom: var(--sp-5) !important; }
.hero-sub { margin: var(--sp-4) 0 var(--sp-5) !important; }
.hero-meta { margin-top: var(--sp-4) !important; }

/* ===========================================================
   SPACING TIGHTEN v6 — 余白をさらに詰める
   =========================================================== */
.section, .usp-triangle, .free-tools, .ceo-trust, .persona-routing,
.compare-section, .material-banner, .final-cta, .why-fukuoka,
.process-section, .faq-section {
  padding-top: clamp(40px, 4.5vw, 72px) !important;
  padding-bottom: clamp(40px, 4.5vw, 72px) !important;
}
.authority-section { padding-top: var(--sp-5) !important; padding-bottom: var(--sp-5) !important; }

.section-head { margin-bottom: clamp(24px, 3vw, 48px) !important; }

.chapter-mark { margin-bottom: var(--sp-3) !important; }
.section-title + .section-lead,
.usp-title + .section-lead,
.material-banner h2 + p,
.final-cta h2 + p { margin-top: clamp(8px, 1vw, 16px) !important; }

/* Section title scale down */
.section-title { font-size: clamp(24px, 3.2vw, 40px) !important; line-height: 1.55 !important; }
.usp-title { font-size: clamp(24px, 3.2vw, 40px) !important; }

/* Hero compress */
.hero { min-height: 78vh !important; }
.hero-h1 { font-size: clamp(34px, 4.6vw, 62px) !important; line-height: 1.4 !important; margin-bottom: var(--sp-4) !important; }
.hero-sub { font-size: 14.5px !important; line-height: 1.95 !important; margin: var(--sp-3) 0 var(--sp-4) !important; }
.hero-en { margin-bottom: var(--sp-4) !important; }
.hero-meta { margin-top: var(--sp-3) !important; }
.scarcity-badge { margin-bottom: var(--sp-3) !important; }
.hero-stats { padding: var(--sp-5) !important; }
.hero-stat { padding: 10px 0 !important; }
.hero-stat-value { font-size: 32px !important; }
.hero-stats-label { padding-bottom: var(--sp-3) !important; margin-bottom: var(--sp-4) !important; }
.hero-inner { gap: var(--sp-6) !important; }

/* Card paddings */
.usp-card { padding: var(--sp-6) var(--sp-5) !important; }
.usp-icon-wrap { margin-bottom: var(--sp-4) !important; padding-bottom: var(--sp-4) !important; }
.usp-h { margin-bottom: var(--sp-3) !important; font-size: 19px !important; }
.usp-p { margin-bottom: var(--sp-4) !important; }
.usp-list { padding-top: var(--sp-3) !important; }

.tool-card { padding: var(--sp-5) !important; }
.tool-badge { margin-bottom: var(--sp-3) !important; }
.tool-h { margin-bottom: var(--sp-3) !important; font-size: 18px !important; }
.tool-p { margin-bottom: var(--sp-3) !important; }
.tool-meta { margin-bottom: var(--sp-3) !important; }
.tool-cta { padding: 12px 16px !important; }

.persona-card .persona-stage { padding: 10px var(--sp-5) !important; }
.persona-stage-num { padding: var(--sp-3) var(--sp-5) 0 !important; font-size: 48px !important; }
.persona-title { padding: var(--sp-2) var(--sp-5) var(--sp-3) !important; font-size: 19px !important; }
.persona-checklist { padding: var(--sp-3) var(--sp-5) !important; }
.persona-checklist li { line-height: 1.85 !important; }
.persona-recommend { margin: 0 var(--sp-5) var(--sp-3) !important; padding: 10px var(--sp-4) !important; }
.persona-cta { margin: 0 var(--sp-5) var(--sp-5) !important; padding: 14px !important; }

.fukuoka-data-card { padding: var(--sp-5) !important; }
.fukuoka-data-en { margin-bottom: var(--sp-3) !important; }
.fukuoka-data-num { margin-bottom: var(--sp-3) !important; font-size: clamp(32px, 3.6vw, 48px) !important; }
.fukuoka-data-title { padding-bottom: var(--sp-3) !important; margin-bottom: var(--sp-3) !important; font-size: 14px !important; line-height: 1.55 !important; }
.fukuoka-data-desc { font-size: 12px !important; line-height: 1.85 !important; }

.strength-card { padding: var(--sp-6) var(--sp-5) !important; }
.strength-num strong { font-size: 48px !important; margin: var(--sp-2) 0 var(--sp-3) !important; }
.strength-title { padding-bottom: var(--sp-3) !important; margin-bottom: var(--sp-3) !important; font-size: 19px !important; }
.strength-tag-row { margin-top: var(--sp-3) !important; padding-top: var(--sp-3) !important; }

.concern-item { padding: var(--sp-5) !important; }
.concern-icon { width: 36px !important; height: 36px !important; margin-bottom: var(--sp-3) !important; }
.concern-num-en { margin-bottom: 4px !important; }
.concern-title { font-size: 16.5px !important; line-height: 1.55 !important; margin-bottom: var(--sp-3) !important; }
.concern-result { margin-top: var(--sp-3) !important; padding: 8px 12px !important; }

.process-step { padding: var(--sp-4) var(--sp-6) !important; margin-bottom: var(--sp-3) !important; }
.process-num { font-size: 48px !important; top: 12px !important; right: 18px !important; }
.process-time { margin-bottom: var(--sp-2) !important; }
.process-step h4 { margin-bottom: var(--sp-2) !important; font-size: 17px !important; }
.process-step p { font-size: 13px !important; line-height: 1.85 !important; }
.process-cta { margin-top: var(--sp-6) !important; }

.faq-list { margin-top: var(--sp-5) !important; }
.faq-item { margin-bottom: 8px !important; }
.faq-item summary { padding: 14px var(--sp-6) !important; padding-right: 50px !important; font-size: 14.5px !important; line-height: 1.55 !important; }
.faq-body { padding: 0 var(--sp-6) var(--sp-4) !important; padding-top: var(--sp-3) !important; margin-top: var(--sp-2) !important; font-size: 13px !important; line-height: 1.9 !important; }

.ward-map-section { padding-top: var(--sp-5) !important; }
.ward-map-head { margin-bottom: var(--sp-5) !important; }
.ward-map-grid { margin-bottom: var(--sp-5) !important; }
.yield-chart-section { margin: var(--sp-5) auto !important; padding: var(--sp-6) var(--sp-5) !important; }
.yield-chart-head { margin-bottom: var(--sp-4) !important; }
.yield-chart-note { margin-top: var(--sp-5) !important; padding-top: var(--sp-4) !important; font-size: 13px !important; }

.ceo-trust-creds { margin: var(--sp-4) 0 !important; padding: var(--sp-4) !important; }
.ceo-trust-creds ul { gap: 4px var(--sp-3) !important; }
.ceo-trust-creds li { font-size: 12px !important; line-height: 1.7 !important; }
.ceo-trust-cta-row { margin-top: var(--sp-4) !important; }
.ceo-trust-h { margin-bottom: var(--sp-4) !important; }
.ceo-trust-tag { margin-bottom: var(--sp-3) !important; }
.ceo-compare { margin-top: var(--sp-3) !important; margin-bottom: var(--sp-4) !important; }
.ceo-compare thead th, .ceo-compare tbody th, .ceo-compare tbody td { padding: 9px 10px !important; font-size: 12px !important; }
.ceo-compare tbody td strong { font-size: 13px !important; }

.btn { padding: 16px 32px !important; font-size: 13px !important; }
.btn-xl { padding: 20px 44px !important; font-size: 14px !important; }
.btn-lg { padding: 18px 36px !important; }

.fukuoka-data-grid, .usp-grid, .tools-grid, .persona-grid, .strengths-grid {
  gap: var(--sp-4) !important;
}

/* ===========================================================
   TOOL CARDS — 顧客目線の訴求要素
   =========================================================== */
.tool-bullets {
  list-style: none;
  margin: 0 0 var(--sp-3);
  padding: 0;
}
.tool-bullets li {
  font-family: var(--sans);
  font-size: 12.5px;
  line-height: 1.85;
  color: var(--brand-text-soft);
  padding-left: 20px;
  position: relative;
  letter-spacing: 0.04em;
  margin-bottom: 6px;
}
.tool-bullets li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 1px;
  color: var(--brand-orange);
  font-weight: 700;
  font-size: 13px;
}
.tool-result {
  background: var(--brand-warm-bg);
  border-left: 3px solid var(--brand-orange);
  padding: 10px 14px;
  font-family: var(--sans);
  font-size: 12px;
  line-height: 1.7;
  color: var(--brand-navy-deep);
  letter-spacing: 0.04em;
  margin-bottom: var(--sp-3);
  border-radius: 0 2px 2px 0;
}
.tool-result strong {
  display: inline-block;
  font-weight: 700;
  color: var(--brand-orange-deep);
  font-size: 11px;
  letter-spacing: 0.12em;
  margin-right: 6px;
  text-transform: uppercase;
}
.tool-h em {
  background: linear-gradient(transparent 64%, rgba(176, 136, 85,0.18) 64%, rgba(176, 136, 85,0.18) 92%, transparent 92%);
  color: var(--brand-orange);
  font-weight: 700;
  font-style: normal;
  padding: 0 4px;
}

/* === Tools Guide (温度別ガイドライン) =========================== */
.tools-guide {
  max-width: 720px;
  margin: var(--sp-7) auto 0;
  background: var(--brand-warm-bg);
  border: 1px solid var(--brand-line);
  border-radius: 4px;
  padding: var(--sp-5) var(--sp-6);
}
.tools-guide-row {
  display: grid;
  grid-template-columns: 60px 100px 30px 1fr;
  gap: var(--sp-3);
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px dashed var(--brand-line);
}
.tools-guide-row:last-child { border-bottom: none; }
.tools-guide-stars {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  color: var(--brand-orange);
  font-size: 14px;
  letter-spacing: 0.05em;
}
.tools-guide-label {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 13px;
  color: var(--brand-navy-deep);
  letter-spacing: 0.04em;
}
.tools-guide-arrow {
  font-family: var(--sans);
  font-size: 14px;
  color: var(--brand-text-light);
  text-align: center;
}
.tools-guide-rec {
  font-family: var(--sans);
  font-size: 13px;
  color: var(--brand-text-soft);
  letter-spacing: 0.04em;
}
@media (max-width: 640px) {
  .tools-guide-row { grid-template-columns: 50px 1fr; }
  .tools-guide-arrow { display: none; }
  .tools-guide-rec { grid-column: 1 / -1; padding-left: 50px; font-size: 12px; color: var(--brand-orange-deep); }
}

/* ===========================================================
   PRIORITY BANNER — 60分相談は具体検討者限定 (アイコン視覚化)
   =========================================================== */
.priority-banner {
  background: linear-gradient(135deg, var(--brand-navy-deep) 0%, var(--brand-navy) 100%);
  color: var(--white);
  padding: var(--sp-7) var(--sp-7);
  border-radius: 4px;
  margin: 0 auto var(--sp-8);
  max-width: 1100px;
  position: relative;
  overflow: hidden;
}
.priority-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 90% 0%, rgba(176, 136, 85,0.18), transparent 60%);
  pointer-events: none;
}
.priority-banner-tag {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 11px;
  color: var(--brand-orange-bright);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  margin-bottom: var(--sp-3);
  position: relative;
}
.priority-banner-text {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: clamp(16px, 2vw, 22px);
  color: var(--white);
  line-height: 1.65;
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-6);
  position: relative;
}
.priority-banner-text strong {
  color: var(--brand-orange-bright);
  background: rgba(176, 136, 85,0.16);
  padding: 1px 6px;
  border-radius: 2px;
  font-weight: 700;
}
.priority-icons {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--sp-4);
  position: relative;
}
.priority-ico {
  text-align: center;
  padding: var(--sp-4) var(--sp-2);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(176, 136, 85,0.3);
  border-radius: 3px;
  transition: all 0.3s;
}
.priority-ico:hover {
  background: rgba(255,255,255,0.1);
  border-color: var(--brand-orange-bright);
  transform: translateY(-3px);
}
.priority-ico-svg {
  width: 36px;
  height: 36px;
  margin: 0 auto var(--sp-3);
  color: var(--brand-orange-bright);
}
.priority-ico-svg svg { width: 100%; height: 100%; }
.priority-ico-l {
  font-family: var(--sans);
  font-weight: 600;
  font-size: 11.5px;
  line-height: 1.55;
  color: rgba(255,255,255,0.92);
  letter-spacing: 0.04em;
}

@media (max-width: 768px) {
  .priority-icons { grid-template-columns: repeat(2, 1fr); }
}

/* ===========================================================
   PROCESS — タイムライン text 大幅削減
   =========================================================== */
.process-step p { display: none !important; }
.process-step h4 { font-size: 16px !important; line-height: 1.4 !important; margin-bottom: 0 !important; }
.process-step { padding: var(--sp-3) var(--sp-5) !important; }
.process-num { font-size: 36px !important; }
.process-time { font-size: 10px !important; }

/* ===========================================================
   CEO TRUST — テキスト3段落非表示・テーブル中心
   =========================================================== */
.ceo-trust-lead { display: none !important; }
.ceo-trust-h { font-size: clamp(20px, 2.6vw, 32px) !important; margin-bottom: var(--sp-3) !important; }

/* ===========================================================
   CONCERNS — 結果バッジを視覚強化
   =========================================================== */
.concerns-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 1px !important;
  background: var(--brand-line);
}
@media (max-width: 768px) { .concerns-grid { grid-template-columns: repeat(2, 1fr) !important; } }
@media (max-width: 480px) { .concerns-grid { grid-template-columns: 1fr !important; } }
.concern-item {
  background: var(--white);
  border: none !important;
}
.concern-item:hover { background: var(--brand-warm-bg); }

/* ===========================================================
   FAQ — 質問だけサマリー表示版
   =========================================================== */
.faq-item summary { font-weight: 600 !important; }
.faq-body { font-size: 12.5px !important; line-height: 1.75 !important; }

/* ===========================================================
   USP — テキスト削減
   =========================================================== */
.usp-p { font-size: 12px !important; line-height: 1.85 !important; margin-bottom: var(--sp-3) !important; }
.usp-list li { font-size: 11.5px !important; line-height: 1.7 !important; }
.usp-h { font-size: 17px !important; }

/* ===========================================================
   TOOL — bullets を圧縮
   =========================================================== */
.tool-bullets li { font-size: 11.5px !important; line-height: 1.55 !important; margin-bottom: 4px !important; }
.tool-result { font-size: 11px !important; padding: 8px 12px !important; line-height: 1.55 !important; }
.tool-result strong { font-size: 10px !important; }
.tool-h { font-size: 16px !important; line-height: 1.55 !important; }
.tool-card { padding: var(--sp-5) var(--sp-5) !important; }

/* ===========================================================
   FORM FIX — radio/labelの縦書き化を解消
   =========================================================== */
.radio-item, .radio-item *, .field-label, label {
  word-break: normal !important;
  overflow-wrap: break-word !important;
  text-wrap: wrap !important;
  white-space: normal !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
}
.radio-item {
  min-height: 56px;
  align-items: center !important;
  justify-content: flex-start !important;
  text-align: left !important;
  padding: 14px 18px !important;
  font-size: 13.5px !important;
  line-height: 1.5 !important;
  letter-spacing: 0.04em !important;
  border-radius: 2px !important;
}
.radio-item input[type=radio], .radio-item input[type=checkbox] {
  flex-shrink: 0;
  margin-right: 10px;
  width: 18px;
  height: 18px;
  accent-color: var(--brand-orange);
}
.radio-group, .radio-group.single {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 10px !important;
}
.radio-group.single { grid-template-columns: repeat(4, 1fr) !important; }
@media (max-width: 768px) {
  .radio-group, .radio-group.single { grid-template-columns: 1fr !important; }
}

/* === Form general polish ===================================== */
.form-box { padding: var(--sp-7) var(--sp-7) !important; }
.form-box h2 {
  font-family: "Shippori Mincho B1", serif;
  font-size: 22px;
  color: var(--brand-navy-deep);
  font-weight: 600;
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--brand-orange);
}
.field { margin-bottom: var(--sp-5); }
.field-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--sans);
  font-weight: 700;
  font-size: 13px;
  color: var(--brand-navy-deep);
  letter-spacing: 0.06em;
  margin-bottom: var(--sp-2);
}
.field-label .req {
  background: var(--brand-orange);
  color: var(--white);
  font-size: 10px;
  letter-spacing: 0.12em;
  padding: 2px 8px;
  border-radius: 2px;
  font-weight: 700;
}
.field-label .opt {
  background: var(--brand-warm-bg);
  color: var(--brand-text-soft);
  font-size: 10px;
  letter-spacing: 0.12em;
  padding: 2px 8px;
  border-radius: 2px;
  font-weight: 600;
}
.field input, .field select, .field textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--brand-line);
  border-radius: 2px;
  background: var(--white);
  font-family: var(--sans);
  font-size: 14px;
  color: var(--brand-text);
  letter-spacing: 0.04em;
  transition: all 0.2s;
}
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none;
  border-color: var(--brand-orange);
  box-shadow: 0 0 0 3px rgba(176, 136, 85,0.12);
}
.field-hint {
  font-family: var(--sans);
  font-size: 11.5px;
  color: var(--brand-text-soft);
  margin-top: 6px;
  letter-spacing: 0.04em;
}
.field-row, .field-row-3 {
  display: grid;
  gap: var(--sp-4);
  margin-bottom: var(--sp-5);
}
.field-row { grid-template-columns: 1fr 1fr; }
.field-row-3 { grid-template-columns: 1fr 1fr 1fr; }
.field-row .field, .field-row-3 .field { margin-bottom: 0; }
@media (max-width: 768px) {
  .field-row, .field-row-3 { grid-template-columns: 1fr; }
}
.privacy-note {
  background: var(--brand-warm-bg);
  border: 1px solid var(--brand-line);
  padding: var(--sp-4);
  font-family: var(--sans);
  font-size: 12px;
  line-height: 1.85;
  color: var(--brand-text-soft);
  letter-spacing: 0.04em;
  margin: var(--sp-5) 0;
  border-radius: 2px;
}
.submit-block { text-align: center; margin-top: var(--sp-6); }

/* === ROA→個別相談 への導線強化バナー ============================ */
.roa-to-consultation {
  background: linear-gradient(135deg, var(--brand-navy-deep) 0%, var(--brand-navy) 100%);
  color: var(--white);
  padding: var(--sp-6) var(--sp-7);
  border-radius: 4px;
  margin: var(--sp-7) auto;
  max-width: 920px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-5);
  align-items: center;
  position: relative;
  overflow: hidden;
}
.roa-to-consultation::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 100% 50%, rgba(176, 136, 85,0.2), transparent 60%);
}
.roa-to-c-text { position: relative; }
.roa-to-c-tag {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 10.5px;
  color: var(--brand-orange-bright);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.roa-to-c-h {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 1.55;
  letter-spacing: 0.05em;
  color: var(--white);
  margin-bottom: 4px;
}
.roa-to-c-h em {
  color: var(--brand-orange-bright);
  font-weight: 700;
  font-style: normal;
}
.roa-to-c-p {
  font-family: var(--sans);
  font-size: 12.5px;
  color: rgba(255,255,255,0.82);
  letter-spacing: 0.05em;
  line-height: 1.7;
}
.roa-to-c-cta {
  background: var(--brand-orange);
  color: var(--white);
  padding: 14px 28px;
  font-family: var(--sans);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.14em;
  border-radius: 2px;
  white-space: nowrap;
  position: relative;
  box-shadow: 0 6px 20px rgba(176, 136, 85,0.35);
  transition: all 0.3s;
}
.roa-to-c-cta:hover { background: var(--brand-orange-deep); transform: translateY(-2px); color: var(--white); }
.roa-to-c-cta::after { content: " →"; }
@media (max-width: 768px) {
  .roa-to-consultation { grid-template-columns: 1fr; }
  .roa-to-c-cta { text-align: center; }
}

/* === Topic Hub — 入口を広げる ============================ */
.topic-hub {
  background: var(--paper);
  padding: var(--sp-10) var(--sp-7);
  border-top: 1px solid var(--line-soft);
}
.topic-hub-inner {
  max-width: 1280px;
  margin: 0 auto;
}
.topic-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
  margin-top: var(--sp-7);
}
.topic-card {
  display: flex;
  flex-direction: column;
  padding: var(--sp-6) var(--sp-5);
  background: var(--white);
  border: 1px solid var(--line-soft);
  border-left: 3px solid var(--gold);
  position: relative;
  transition: all 0.4s cubic-bezier(0.22, 0.61, 0.36, 1);
  text-decoration: none;
  color: inherit;
  min-height: 270px;
}
.topic-card:hover {
  border-left-color: var(--accent-vermillion);
  transform: translateY(-3px);
  box-shadow: 0 12px 30px rgba(10,23,41,0.10);
  color: inherit;
}
.topic-card .topic-num {
  font-family: var(--serif-en);
  font-style: italic;
  font-weight: 500;
  font-size: 14px;
  color: var(--gold);
  letter-spacing: 0.12em;
  margin-bottom: 4px;
}
.topic-card .topic-tag {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 10px;
  color: var(--accent-vermillion);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  margin-bottom: var(--sp-3);
}
.topic-card .topic-h {
  font-family: var(--mincho-display);
  font-weight: 600;
  font-size: 19px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: var(--text);
  margin-bottom: var(--sp-3);
}
.topic-card .topic-p {
  font-family: var(--sans);
  font-size: 12.5px;
  line-height: 1.75;
  color: var(--text-mid);
  margin-bottom: var(--sp-4);
  letter-spacing: 0.04em;
  flex: 1;
}
.topic-card .topic-link {
  font-family: var(--sans);
  font-size: 11.5px;
  font-weight: 700;
  color: var(--accent-vermillion);
  letter-spacing: 0.16em;
  margin-top: auto;
}
@media (max-width: 1024px) {
  .topic-grid { grid-template-columns: repeat(2, 1fr); }
  .topic-card { min-height: 240px; }
}
@media (max-width: 640px) {
  .topic-hub { padding: var(--sp-8) var(--sp-5); }
  .topic-grid { grid-template-columns: 1fr; gap: var(--sp-4); }
  .topic-card { min-height: 0; }
}

/* === End-of-page Bridge: 次に読む + 温度別CTA ============================ */
.next-bridge {
  background: var(--paper-warm);
  padding: var(--sp-9) var(--sp-7);
  border-top: 3px solid var(--gold);
}
.next-bridge-inner { max-width: 1080px; margin: 0 auto; }

.next-reads { margin-bottom: var(--sp-8); }
.next-reads-label, .temp-cta-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 13px;
  color: var(--gold);
  letter-spacing: 0.18em;
  text-align: center;
  margin-bottom: var(--sp-2);
}
.next-reads-h, .temp-cta-h {
  font-family: var(--mincho-display);
  font-size: 24px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: 0.06em;
  text-align: center;
  margin-bottom: var(--sp-6);
  line-height: 1.5;
}
.next-reads-h em, .temp-cta-h em { color: var(--accent-vermillion); font-style: normal; }

.next-reads-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-5);
}
.next-read-card {
  display: block;
  padding: var(--sp-6) var(--sp-5);
  background: var(--white);
  border: 1px solid var(--line-soft);
  border-left: 3px solid var(--gold);
  text-decoration: none;
  color: inherit;
  transition: all 0.4s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.next-read-card:hover {
  border-left-color: var(--accent-vermillion);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(10,23,41,0.08);
  color: inherit;
}
.next-read-tag {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 10px;
  color: var(--accent-vermillion);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.next-read-h {
  font-family: var(--mincho-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.5;
  letter-spacing: 0.04em;
  margin-bottom: 8px;
}
.next-read-p {
  font-family: var(--sans);
  font-size: 12px;
  line-height: 1.75;
  color: var(--text-mid);
  letter-spacing: 0.04em;
}

.temp-cta {
  border-top: 1px solid var(--line);
  padding-top: var(--sp-7);
}
.temp-cta-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
}
.temp-cta-card {
  display: flex;
  flex-direction: column;
  padding: var(--sp-5) var(--sp-5);
  background: var(--white);
  border: 1px solid var(--line-soft);
  text-decoration: none;
  color: inherit;
  transition: all 0.4s cubic-bezier(0.22, 0.61, 0.36, 1);
  position: relative;
}
.temp-cta-card:hover {
  border-color: var(--accent-vermillion);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(10,23,41,0.08);
  color: inherit;
}
.temp-cta-card.highlighted {
  border: 2px solid var(--accent-vermillion);
  background: linear-gradient(135deg, var(--accent-vermillion), var(--accent-vermillion-dark));
  color: var(--paper);
}
.temp-cta-card.highlighted .temp-cta-card-h,
.temp-cta-card.highlighted .temp-cta-card-p { color: var(--paper); }
.temp-cta-card-stars {
  font-size: 13px;
  letter-spacing: 0.12em;
  color: var(--gold);
  margin-bottom: 4px;
}
.temp-cta-card.highlighted .temp-cta-card-stars { color: var(--gold-bright); }
.temp-cta-card-temp {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 9.5px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-soft);
  margin-bottom: var(--sp-3);
}
.temp-cta-card.highlighted .temp-cta-card-temp { color: var(--gold-bright); }
.temp-cta-card-h {
  font-family: var(--mincho-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 8px;
  line-height: 1.5;
  letter-spacing: 0.04em;
}
.temp-cta-card-p {
  font-family: var(--sans);
  font-size: 11.5px;
  line-height: 1.75;
  color: var(--text-mid);
  margin-bottom: var(--sp-4);
  letter-spacing: 0.04em;
  flex: 1;
}
.temp-cta-card-link {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  margin-top: auto;
  color: var(--accent-vermillion);
}
.temp-cta-card.highlighted .temp-cta-card-link { color: var(--gold-bright); }

@media (max-width: 1024px) {
  .next-reads-grid { grid-template-columns: 1fr; }
  .temp-cta-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .next-bridge { padding: var(--sp-8) var(--sp-5); }
  .next-reads-h, .temp-cta-h { font-size: 20px; }
}

/* === Temp CTA refined: chapter-mark style tag (replaces stars/temp) === */
.temp-cta-card-tag {
  font-family: var(--serif-en);
  font-style: italic;
  font-weight: 500;
  font-size: 11.5px;
  letter-spacing: 0.32em;
  color: var(--gold);
  margin-bottom: var(--sp-3);
}
.temp-cta-card.highlighted .temp-cta-card-tag { color: var(--gold-bright); }

/* === Refined Tool Cards — 上品化 (badge/meta less loud) === */
.tool-badge,
.tool-badge.free {
  background: transparent !important;
  color: var(--gold) !important;
  font-family: var(--serif-en) !important;
  font-style: italic !important;
  font-weight: 500 !important;
  font-size: 11.5px !important;
  letter-spacing: 0.32em !important;
  padding: 0 !important;
  border-radius: 0 !important;
  text-transform: none !important;
  border: none !important;
  margin-bottom: var(--sp-4) !important;
}
.tool-meta {
  border-top: 1px solid var(--line-soft);
  padding-top: var(--sp-3);
  margin-top: var(--sp-3);
}
.tool-meta span {
  background: transparent !important;
  color: var(--text-soft) !important;
  font-family: var(--sans) !important;
  font-size: 10.5px !important;
  font-weight: 500 !important;
  letter-spacing: 0.16em !important;
  padding: 0 !important;
  border-radius: 0 !important;
  position: relative;
  padding-right: var(--sp-3) !important;
}
.tool-meta span:not(:last-child)::after {
  content: "·";
  position: absolute;
  right: 4px;
  color: var(--line);
}
.tool-cta {
  background: transparent !important;
  color: var(--ink-deep) !important;
  border-top: 1px solid var(--gold);
  padding: var(--sp-4) 0 0 0 !important;
  font-size: 12.5px !important;
  letter-spacing: 0.16em !important;
  border-radius: 0 !important;
  text-align: left;
}
.tool-cta:hover {
  background: transparent !important;
  color: var(--accent-vermillion) !important;
}
.tool-card:hover .tool-cta { color: var(--accent-vermillion) !important; }

/* Refine "あなたが得るもの" callout — make subtle */
.tool-result {
  background: var(--paper-warm) !important;
  border-left: 2px solid var(--gold) !important;
  border-right: none !important;
  border-top: none !important;
  border-bottom: none !important;
  padding: var(--sp-3) var(--sp-4) !important;
  font-size: 12px !important;
  line-height: 1.85 !important;
  color: var(--text) !important;
  border-radius: 0 !important;
  margin-bottom: var(--sp-4) !important;
}
.tool-result strong {
  color: var(--gold-deep) !important;
  font-weight: 600 !important;
  font-family: var(--serif-en) !important;
  font-style: italic !important;
  letter-spacing: 0.12em !important;
  font-size: 11px !important;
  display: block;
  margin-bottom: 4px;
}

/* Refine persona-stage label (was orange filled badge) */
.persona-stage {
  background: transparent !important;
  color: var(--gold) !important;
  font-family: var(--serif-en) !important;
  font-style: italic !important;
  font-weight: 500 !important;
  font-size: 11.5px !important;
  letter-spacing: 0.32em !important;
  padding: var(--sp-5) var(--sp-6) 0 !important;
  text-transform: none !important;
  border-radius: 0 !important;
}

/* Priority banner — make less heavy */
.priority-banner {
  background: var(--paper-warm) !important;
  color: var(--ink-deep) !important;
  border: 1px solid var(--gold) !important;
}
.priority-banner-tag {
  color: var(--gold-deep) !important;
}
.priority-banner-text {
  color: var(--text) !important;
}
.priority-banner-text strong {
  color: var(--ink-deep) !important;
}
.priority-icons {
  border-top: 1px solid var(--line-soft) !important;
}
.priority-ico {
  color: var(--ink-deep) !important;
}
.priority-ico-svg {
  background: var(--white) !important;
  border: 1px solid var(--gold-light) !important;
  color: var(--gold-deep) !important;
}
.priority-ico-l {
  color: var(--text-mid) !important;
}

/* ===========================================================
   ANIMATION & MICROINTERACTION LAYER (v2 polish)
   =========================================================== */

/* Reading progress bar (top of page) */
.reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--gold), var(--accent-vermillion));
  z-index: 999;
  transition: width 0.1s linear;
  width: 0;
  pointer-events: none;
}

/* Refined reveal animations — smoother, longer */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal, .reveal.is-visible { transition: none !important; transform: none !important; opacity: 1 !important; filter: none !important; }
}
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
  /* Fail-safe: auto-reveal after 2.5s in case JS doesn't trigger */
  animation: autoReveal 0.01s 2.5s forwards;
}
.reveal.is-visible {
  opacity: 1;
  transform: none;
  animation: none;
}
@keyframes autoReveal {
  to { opacity: 1; transform: none; }
}

/* Form pages: disable reveal animation entirely (no scroll required to see content) */
body.form-page .reveal,
.inquiry-form .reveal,
.inquiry-side .reveal,
.field.reveal,
.inquiry-side-block.reveal {
  opacity: 1 !important;
  transform: none !important;
  animation: none !important;
  transition: none !important;
}

/* Smoother card hover transitions across the site */
.tool-card, .topic-card, .persona-card, .voice-card, .voice-block,
.next-read-card, .temp-cta-card, .area-card, .blog-card, .pillar-card,
.usp-card, .strength-card, .concern-item, .onestop-item {
  transition:
    transform 0.5s cubic-bezier(0.22, 0.61, 0.36, 1),
    box-shadow 0.5s cubic-bezier(0.22, 0.61, 0.36, 1),
    border-color 0.4s ease,
    background 0.4s ease;
}
.tool-card:hover, .topic-card:hover, .persona-card:hover,
.next-read-card:hover, .temp-cta-card:hover, .blog-card:hover,
.pillar-card:hover, .usp-card:hover, .strength-card:hover {
  transform: translateY(-6px);
}
.area-card:hover { transform: translateY(-8px) scale(1.005); }
.voice-card:hover { transform: translateY(-4px); }
.voice-block:hover .voice-photo-lg img,
.area-card:hover .area-card-img,
.next-read-card:hover img, .temp-cta-card:hover img {
  transform: scale(1.04);
}
.voice-photo-lg img, .area-card-img {
  transition: transform 0.8s cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* Smoother button/link transitions */
.btn, .global-nav a, .footer-col a, .topic-link, .area-card-link,
.tool-cta, .temp-cta-card-link, .voice-cta {
  transition:
    transform 0.3s cubic-bezier(0.22, 0.61, 0.36, 1),
    background 0.3s ease,
    color 0.3s ease,
    box-shadow 0.3s ease,
    border-color 0.3s ease;
}
.btn:hover { transform: translateY(-2px); }

/* Smoother sticky header */
.site-header { transition: transform 0.5s cubic-bezier(0.22,0.61,0.36,1), background 0.4s ease, box-shadow 0.4s ease, backdrop-filter 0.4s ease; }

/* Hero subtle fade-in on page load */
@keyframes heroFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.hero-inner > * {
  animation: heroFadeIn 1.0s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.hero-inner > *:nth-child(1) { animation-delay: 0.05s; }
.hero-inner > *:nth-child(2) { animation-delay: 0.18s; }
.hero-stats { animation: heroFadeIn 1.0s cubic-bezier(0.16, 1, 0.3, 1) 0.32s both; }

/* Section heading underline-on-reveal */
.section-title em, .ceo-trust-h em, .usp-title em, .onestop-title em,
.voice-quote-lg em, .pp-h em, .st-section-h em {
  background-size: 100% 100%;
  background-repeat: no-repeat;
  transition: background-size 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal .section-title em, .reveal .ceo-trust-h em, .reveal .usp-title em {
  background-size: 0% 100%;
}
.reveal.is-visible .section-title em, .reveal.is-visible .ceo-trust-h em, .reveal.is-visible .usp-title em {
  background-size: 100% 100%;
}

/* Stagger child elements (CSS custom property based) */
.stagger > * {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1) calc(var(--i, 0) * 80ms),
    transform 0.8s cubic-bezier(0.16, 1, 0.3, 1) calc(var(--i, 0) * 80ms);
}
.stagger.is-visible > * {
  opacity: 1;
  transform: none;
}

/* Topic card refined hover (more elegant lift) */
.topic-card {
  transition:
    transform 0.5s cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 0.5s cubic-bezier(0.16, 1, 0.3, 1),
    border-left-color 0.4s ease;
  position: relative;
  overflow: hidden;
}
.topic-card::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 0;
  height: 2px;
  background: var(--accent-vermillion);
  transition: width 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}
.topic-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 48px rgba(10, 23, 41, 0.12);
}
.topic-card:hover::after {
  width: 100%;
}
.topic-card .topic-link {
  transition: letter-spacing 0.4s ease, color 0.3s ease;
}
.topic-card:hover .topic-link {
  letter-spacing: 0.22em;
}

/* Tool card refined hover with subtle gold gleam */
.tool-card {
  transition:
    transform 0.5s cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 0.5s cubic-bezier(0.16, 1, 0.3, 1) !important;
  position: relative;
  overflow: hidden;
}
.tool-card::after {
  content: "";
  position: absolute;
  top: -50%;
  left: -100%;
  width: 200%;
  height: 200%;
  background: linear-gradient(115deg, transparent 30%, rgba(176, 136, 85, 0.08) 50%, transparent 70%);
  transition: left 0.9s cubic-bezier(0.16, 1, 0.3, 1);
  pointer-events: none;
}
.tool-card:hover::after {
  left: 100%;
}
.tool-card:hover {
  transform: translateY(-8px) !important;
}

/* Next-read card hover (similar) */
.next-read-card {
  transition:
    transform 0.5s cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 0.5s cubic-bezier(0.16, 1, 0.3, 1),
    border-left-color 0.4s ease;
  position: relative;
  overflow: hidden;
}
.next-read-card::after {
  content: "→";
  position: absolute;
  top: var(--sp-5);
  right: var(--sp-5);
  font-family: var(--serif-en);
  color: var(--gold);
  font-size: 18px;
  opacity: 0;
  transform: translateX(-8px);
  transition: opacity 0.4s ease, transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.next-read-card:hover::after {
  opacity: 1;
  transform: translateX(0);
}

/* Temp CTA cards: subtle hover lift */
.temp-cta-card {
  transition:
    transform 0.5s cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 0.5s cubic-bezier(0.16, 1, 0.3, 1),
    border-color 0.4s ease;
}
.temp-cta-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 40px rgba(10, 23, 41, 0.12);
}
.temp-cta-card .temp-cta-card-link {
  position: relative;
  transition: letter-spacing 0.4s ease;
}
.temp-cta-card:hover .temp-cta-card-link {
  letter-spacing: 0.22em;
}

/* Persona card refined hover */
.persona-card {
  transition:
    transform 0.5s cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 0.5s cubic-bezier(0.16, 1, 0.3, 1) !important;
  position: relative;
  overflow: hidden;
}
.persona-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 32px 64px rgba(10, 23, 41, 0.14);
}

/* CTA buttons: enhanced hover with shimmer */
.btn-primary,
.btn-gold,
.btn-vermillion {
  position: relative;
  overflow: hidden;
}
.btn-primary::before,
.btn-gold::before,
.btn-vermillion::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.18), transparent);
  transition: left 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.btn-primary:hover::before,
.btn-gold:hover::before,
.btn-vermillion:hover::before {
  left: 100%;
}

/* Section heading underline animation */
.section-title {
  position: relative;
  display: inline-block;
}
.section-head .section-title::after {
  content: "";
  display: block;
  width: 0;
  height: 1px;
  margin: var(--sp-3) auto 0;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  transition: width 1.2s cubic-bezier(0.16, 1, 0.3, 1) 0.3s;
}
.section-head.is-visible .section-title::after {
  width: 80px;
}

/* Hero stats subtle reveal */
.hero-stat {
  opacity: 0;
  transform: translateX(-12px);
  animation: fadeInRight 0.9s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.hero-stat:nth-child(1) { animation-delay: 0.6s; }
.hero-stat:nth-child(2) { animation-delay: 0.7s; }
.hero-stat:nth-child(3) { animation-delay: 0.8s; }
.hero-stat:nth-child(4) { animation-delay: 0.9s; }

@keyframes fadeInRight {
  to { opacity: 1; transform: none; }
}

/* Hero title staggered reveal */
.hero-en {
  opacity: 0;
  transform: translateY(16px);
  animation: fadeUp 0.9s cubic-bezier(0.16, 1, 0.3, 1) 0.1s forwards;
}
.hero-h1 {
  opacity: 0;
  transform: translateY(24px);
  animation: fadeUp 1.0s cubic-bezier(0.16, 1, 0.3, 1) 0.3s forwards;
}
.hero-sub {
  opacity: 0;
  transform: translateY(20px);
  animation: fadeUp 0.9s cubic-bezier(0.16, 1, 0.3, 1) 0.6s forwards;
}
.scarcity-badge.in-hero,
.hero-cta-row {
  opacity: 0;
  transform: translateY(16px);
  animation: fadeUp 0.9s cubic-bezier(0.16, 1, 0.3, 1) 0.85s forwards;
}
.hero-meta {
  opacity: 0;
  transform: translateY(16px);
  animation: fadeUp 0.9s cubic-bezier(0.16, 1, 0.3, 1) 1.0s forwards;
}

@keyframes fadeUp {
  to { opacity: 1; transform: none; }
}

/* Subtle floating motion on hero stats panel */
.hero-stats {
  animation: floatY 8s ease-in-out infinite;
}
@keyframes floatY {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

/* Smooth scroll behavior */
html {
  scroll-behavior: smooth;
}

/* Sticky bottom CTA bar (selling-site essential) */
.bottom-cta-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: linear-gradient(180deg, rgba(10, 23, 41, 0.95), rgba(10, 23, 41, 0.98));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding: var(--sp-3) var(--sp-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  border-top: 1px solid rgba(176, 136, 85, 0.3);
  transform: translateY(100%);
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}
.bottom-cta-bar.is-visible {
  transform: translateY(0);
}
.bottom-cta-text {
  font-family: var(--mincho);
  font-size: 12.5px;
  color: var(--paper);
  letter-spacing: 0.06em;
  flex: 1;
  line-height: 1.5;
}
.bottom-cta-text strong {
  color: var(--gold-bright);
  font-weight: 500;
}
.bottom-cta-buttons {
  display: flex;
  gap: var(--sp-2);
}
.bottom-cta-btn {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  padding: 10px 18px;
  letter-spacing: 0.1em;
  text-decoration: none;
  white-space: nowrap;
  transition: all 0.3s ease;
  border: 1px solid transparent;
}
.bottom-cta-btn.primary {
  background: var(--accent-vermillion);
  color: var(--paper);
}
.bottom-cta-btn.primary:hover {
  background: var(--accent-vermillion-dark);
  transform: translateY(-1px);
}
.bottom-cta-btn.secondary {
  background: transparent;
  color: var(--paper);
  border-color: rgba(176, 136, 85, 0.4);
}
.bottom-cta-btn.secondary:hover {
  border-color: var(--gold);
  color: var(--gold-bright);
}
@media (max-width: 640px) {
  .bottom-cta-bar { padding: var(--sp-2) var(--sp-3); gap: var(--sp-2); }
  .bottom-cta-text { font-size: 11px; }
  .bottom-cta-btn { padding: 8px 12px; font-size: 11px; }
}

/* Form field elegant focus */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
select,
textarea {
  transition:
    border-color 0.3s ease,
    box-shadow 0.3s ease,
    background-color 0.3s ease !important;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
select:focus,
textarea:focus {
  border-color: var(--gold) !important;
  box-shadow: 0 0 0 3px rgba(176, 136, 85, 0.12) !important;
  outline: none !important;
}

/* Radio item refined */
.radio-item {
  transition: all 0.3s ease;
  position: relative;
}
.radio-item:hover {
  border-color: var(--gold) !important;
  background: var(--paper-warm) !important;
}
.radio-item:has(input:checked) {
  border-color: var(--gold) !important;
  background: var(--paper-warm) !important;
}

/* Animated gradient on chapter marks */
.chapter-mark,
.next-reads-label,
.temp-cta-label {
  background: linear-gradient(90deg, var(--gold-deep), var(--gold), var(--gold-bright), var(--gold), var(--gold-deep));
  background-size: 300% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: shimmerGold 6s ease-in-out infinite;
}
@keyframes shimmerGold {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

/* CSSEOF */

/* =============================================================================
   Inquiry Pages — Refined Form Aesthetics (consultation, roa-request, etc.)
   ============================================================================= */

/* --- Hero --------------------------------------------------------------- */
.inquiry-hero {
  position: relative;
  background: linear-gradient(135deg, #0a1729 0%, #112545 55%, #1a3158 100%);
  color: var(--paper);
  padding: clamp(72px, 9vw, 128px) var(--sp-7) clamp(64px, 7vw, 104px);
  overflow: hidden;
}
.inquiry-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(ellipse 800px 400px at 20% 10%, rgba(176,136,85,0.18), transparent 60%),
    radial-gradient(ellipse 600px 380px at 88% 90%, rgba(226,199,154,0.10), transparent 65%);
  pointer-events: none;
}
.inquiry-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 60'><path d='M0 30 L60 30 M30 0 L30 60' stroke='%23ffffff' stroke-width='0.3' stroke-opacity='0.04'/></svg>");
  background-size: 60px 60px;
  pointer-events: none;
  opacity: 0.6;
}
.inquiry-hero-inner {
  position: relative;
  z-index: 2;
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
}
.inquiry-hero-meta {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold-bright);
  letter-spacing: 0.42em;
  margin-bottom: var(--sp-5);
  font-weight: 500;
}
.inquiry-hero-h {
  font-family: var(--mincho-display);
  font-size: clamp(34px, 4.8vw, 60px);
  color: var(--paper);
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: 0.08em;
  margin-bottom: var(--sp-6);
}
.inquiry-hero-h em {
  font-style: normal;
  background: linear-gradient(90deg, var(--gold-bright), #f0d6a8, var(--gold-bright));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.inquiry-hero-lead {
  font-family: var(--mincho);
  font-size: clamp(14px, 1.1vw, 16px);
  color: rgba(250, 247, 240, 0.88);
  line-height: 2.1;
  letter-spacing: 0.08em;
  max-width: 720px;
  margin: 0 auto var(--sp-9);
}
.inquiry-hero-trust {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-2);
  max-width: 760px;
  margin: 0 auto;
  border-top: 1px solid rgba(226, 199, 154, 0.32);
  border-bottom: 1px solid rgba(226, 199, 154, 0.32);
  padding: var(--sp-5) 0;
}
.inquiry-trust-item {
  text-align: center;
  padding: 0 var(--sp-4);
  border-right: 1px solid rgba(226, 199, 154, 0.18);
}
.inquiry-trust-item:last-child { border-right: none; }
.inquiry-trust-num {
  font-family: var(--serif-en);
  font-style: italic;
  font-weight: 500;
  font-size: 11px;
  color: var(--gold-bright);
  letter-spacing: 0.32em;
  margin-bottom: 6px;
}
.inquiry-trust-txt {
  font-family: var(--mincho);
  font-size: 13.5px;
  color: var(--paper);
  letter-spacing: 0.1em;
  font-weight: 500;
}

/* --- Section wrap ------------------------------------------------------- */
.inquiry-section {
  background: linear-gradient(180deg, var(--cream) 0%, var(--paper) 100%);
  padding: clamp(64px, 8vw, 120px) var(--sp-7);
  position: relative;
}
.inquiry-shell {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: clamp(32px, 4vw, 56px);
  align-items: start;
}

/* --- Side panel --------------------------------------------------------- */
.inquiry-side { position: sticky; top: 110px; }
.inquiry-side-block { margin-bottom: var(--sp-9); }
.inquiry-side-block:last-child { margin-bottom: 0; }
.inquiry-side-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-weight: 500;
  font-size: 11px;
  color: var(--gold-deep);
  letter-spacing: 0.4em;
  margin-bottom: var(--sp-3);
}
.inquiry-side-h {
  font-family: var(--mincho-display);
  font-size: 19px;
  color: var(--ink-deep);
  font-weight: 500;
  letter-spacing: 0.06em;
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--gold);
  position: relative;
}
.inquiry-side-h::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 32px;
  height: 1px;
  background: var(--gold-deep);
}
.inquiry-step-list { list-style: none; counter-reset: step; padding: 0; }
.inquiry-step-list li {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
  position: relative;
}
.inquiry-step-list li:not(:last-child)::before {
  content: "";
  position: absolute;
  left: 22px;
  top: 38px;
  bottom: -16px;
  width: 1px;
  background: linear-gradient(to bottom, var(--gold-light), transparent);
}
.inquiry-step-num {
  width: 44px;
  height: 44px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--serif-en);
  font-style: italic;
  font-weight: 500;
  font-size: 14px;
  color: var(--gold-deep);
  background: var(--white);
  position: relative;
  z-index: 1;
}
.inquiry-step-h {
  font-family: var(--mincho);
  font-size: 14px;
  color: var(--ink-deep);
  font-weight: 600;
  letter-spacing: 0.08em;
  margin-bottom: 4px;
}
.inquiry-step-p {
  font-family: var(--mincho);
  font-size: 12.5px;
  color: var(--text-soft);
  line-height: 1.85;
  letter-spacing: 0.04em;
}
.inquiry-promise-list {
  list-style: none;
  padding: 0;
  background: var(--white);
  border: 1px solid var(--line-soft);
  border-left: 3px solid var(--gold);
}
.inquiry-promise-list li {
  font-family: var(--mincho);
  font-size: 12.5px;
  color: var(--text);
  line-height: 1.7;
  padding: 12px var(--sp-4) 12px var(--sp-7);
  border-bottom: 1px dashed var(--line-soft);
  letter-spacing: 0.05em;
  position: relative;
}
.inquiry-promise-list li:last-child { border-bottom: none; }
.inquiry-promise-list li::before {
  content: "✓";
  position: absolute;
  left: var(--sp-4);
  top: 12px;
  color: var(--gold-deep);
  font-weight: 700;
  font-size: 13px;
}

/* --- Form --------------------------------------------------------------- */
.inquiry-form {
  background: var(--white);
  padding: clamp(36px, 5vw, 72px);
  border: 1px solid var(--line);
  position: relative;
  box-shadow: 0 32px 64px -32px rgba(10, 23, 41, 0.12);
}
.inquiry-form::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}
.inquiry-form > * { position: relative; z-index: 1; }
.inquiry-form-meta {
  font-family: var(--serif-en);
  font-style: italic;
  font-weight: 500;
  font-size: 11px;
  color: var(--gold-deep);
  letter-spacing: 0.4em;
  margin-bottom: var(--sp-3);
}
.inquiry-form-h {
  font-family: var(--mincho-display);
  font-size: clamp(24px, 2.6vw, 32px);
  color: var(--ink-deep);
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.5;
  margin-bottom: var(--sp-3);
}
.inquiry-form-h em {
  font-style: normal;
  color: var(--gold-deep);
}
.inquiry-form-sub {
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--text-soft);
  letter-spacing: 0.06em;
  line-height: 1.85;
  margin-bottom: var(--sp-8);
  padding-bottom: var(--sp-6);
  border-bottom: 1px solid var(--line-soft);
}

/* Field-level overrides inside .inquiry-form */
.inquiry-form .field { margin-bottom: var(--sp-7); }
.inquiry-form .field-label {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--mincho);
  font-size: 13px;
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.12em;
  margin-bottom: var(--sp-3);
  position: relative;
}
.inquiry-form .field-label::before {
  content: "";
  width: 16px;
  height: 1px;
  background: var(--gold);
  margin-right: var(--sp-1);
}
.inquiry-form .field-label .req,
.inquiry-form .field-label .opt {
  font-family: var(--serif-en);
  font-style: italic;
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.18em;
  padding: 3px 9px;
  border-radius: 0;
}
.inquiry-form .field-label .req {
  color: var(--accent-vermillion);
  background: transparent;
  border: 1px solid var(--accent-vermillion);
}
.inquiry-form .field-label .opt {
  color: var(--text-soft);
  background: transparent;
  border: 1px solid var(--line);
}
.inquiry-form .field input[type="text"],
.inquiry-form .field input[type="email"],
.inquiry-form .field input[type="tel"],
.inquiry-form .field textarea,
.inquiry-form .field select {
  width: 100%;
  padding: 16px 18px;
  border: 1px solid transparent;
  border-bottom: 1px solid var(--line);
  background: var(--cream);
  font-family: var(--mincho);
  font-size: 14.5px;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  transition: var(--t-fast);
  border-radius: 0;
}
.inquiry-form .field input:focus,
.inquiry-form .field textarea:focus,
.inquiry-form .field select:focus {
  outline: none;
  background: var(--white);
  border-color: var(--gold);
  box-shadow: 0 4px 0 -1px var(--gold), 0 0 0 4px rgba(176, 136, 85, 0.08);
}
.inquiry-form .field input::placeholder,
.inquiry-form .field textarea::placeholder {
  color: var(--text-light);
  letter-spacing: 0.04em;
  font-style: italic;
}
.inquiry-form .field-hint {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--mincho);
  font-size: 11.5px;
  color: var(--text-soft);
  margin-top: 8px;
  letter-spacing: 0.06em;
}
.inquiry-form .field-hint::before {
  content: "i";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1px solid var(--gold-light);
  color: var(--gold-deep);
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 10px;
  font-weight: 500;
}

/* Card-style radios (replace browser default) — needs !important to override
   the form-fix block earlier in main.css */
.inquiry-form .radio-group,
.inquiry-form .radio-group.single { gap: 12px !important; }
.inquiry-form .radio-item {
  position: relative !important;
  border: 1px solid var(--line) !important;
  background: var(--cream) !important;
  padding: 18px 22px 18px 52px !important;
  font-family: var(--mincho) !important;
  font-size: 14px !important;
  color: var(--ink-deep) !important;
  letter-spacing: 0.06em !important;
  cursor: pointer;
  transition: var(--t-fast);
  border-radius: 0 !important;
  min-height: 60px !important;
  display: flex;
  align-items: center !important;
}
.inquiry-form .radio-item input[type="radio"],
.inquiry-form .radio-item input[type="checkbox"] {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
}
.inquiry-form .radio-item::before {
  content: "";
  position: absolute;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  background: var(--white);
  transition: var(--t-fast);
}
.inquiry-form .radio-item::after {
  content: "";
  position: absolute;
  left: 25px;
  top: 50%;
  transform: translateY(-50%) scale(0);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold);
  transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.inquiry-form .radio-item:hover {
  border-color: var(--gold) !important;
  background: var(--white) !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 24px -8px rgba(176, 136, 85, 0.25);
}
.inquiry-form .radio-item:hover::before { border-color: var(--gold); }
.inquiry-form .radio-item:has(input:checked) {
  border-color: var(--gold-deep) !important;
  background: var(--white) !important;
  box-shadow: inset 0 0 0 1px var(--gold-deep);
}
.inquiry-form .radio-item:has(input:checked)::before { border-color: var(--gold-deep); }
.inquiry-form .radio-item:has(input:checked)::after { transform: translateY(-50%) scale(1); }

/* Privacy note refined */
.inquiry-form .privacy-note {
  background: linear-gradient(180deg, var(--cream) 0%, var(--paper-warm) 100%);
  border: none;
  border-left: 2px solid var(--gold);
  padding: var(--sp-5) var(--sp-6);
  font-family: var(--mincho);
  font-size: 12px;
  color: var(--text);
  line-height: 2;
  letter-spacing: 0.05em;
  margin: var(--sp-7) 0;
  position: relative;
}
.inquiry-form .privacy-note::before {
  content: "Privacy";
  display: block;
  font-family: var(--serif-en);
  font-style: italic;
  font-weight: 500;
  font-size: 10px;
  color: var(--gold-deep);
  letter-spacing: 0.4em;
  margin-bottom: 6px;
}

/* Submit area */
.inquiry-form .submit-block,
.inquiry-form .submit-area {
  text-align: center;
  padding-top: var(--sp-7);
  border-top: 1px solid var(--line-soft);
  margin-top: var(--sp-3);
}
.inquiry-submit,
.inquiry-form .submit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  background: var(--ink-deep);
  color: var(--paper);
  padding: 22px 64px;
  font-family: var(--mincho);
  font-size: 15px;
  font-weight: 500;
  border: 1px solid var(--gold);
  cursor: pointer;
  letter-spacing: 0.32em;
  position: relative;
  transition: var(--t);
  overflow: hidden;
  text-decoration: none;
  min-width: 320px;
}
.inquiry-submit::before,
.inquiry-form .submit-btn::before {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px solid rgba(226, 199, 154, 0.35);
  pointer-events: none;
  transition: inset 0.3s ease;
}
.inquiry-submit::after,
.inquiry-form .submit-btn::after {
  content: "→";
  font-size: 18px;
  letter-spacing: 0;
  transition: transform 0.3s ease;
}
.inquiry-submit:hover,
.inquiry-form .submit-btn:hover {
  background: var(--ink);
  transform: translateY(-2px);
  box-shadow: 0 24px 48px -12px rgba(10, 23, 41, 0.5);
}
.inquiry-submit:hover::before,
.inquiry-form .submit-btn:hover::before { inset: 7px; border-color: var(--gold-bright); }
.inquiry-submit:hover::after,
.inquiry-form .submit-btn:hover::after { transform: translateX(6px); }
.submit-hint {
  display: block;
  font-family: var(--mincho);
  font-size: 11.5px;
  color: var(--text-soft);
  margin-top: var(--sp-4);
  letter-spacing: 0.18em;
}

/* Field group titles (optional dividers within long forms) */
.field-group {
  margin-top: var(--sp-9);
  padding-top: var(--sp-7);
  border-top: 1px dashed var(--line-soft);
}
.field-group:first-of-type { margin-top: 0; padding-top: 0; border-top: none; }
.field-group-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-weight: 500;
  font-size: 10.5px;
  color: var(--gold-deep);
  letter-spacing: 0.4em;
  margin-bottom: var(--sp-2);
}
.field-group-h {
  font-family: var(--mincho-display);
  font-size: 17px;
  color: var(--ink-deep);
  font-weight: 500;
  letter-spacing: 0.06em;
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--gold-light);
}

/* --- Reveal animation enhancement for inquiry pages -------------------- */
/* Inquiry forms stay visible by default; the .reveal class on fields is decorative
   only — actual fade-in is handled by IntersectionObserver in conversion-ux.js
   which adds .is-visible. Default state must be visible so forms render with no JS. */
.inquiry-form .field.reveal,
.inquiry-side-block.reveal { opacity: 1; transform: none; transition: opacity 0.6s ease, transform 0.6s cubic-bezier(0.2, 0.6, 0.2, 1); }

/* --- Responsive --------------------------------------------------------- */
@media (max-width: 1024px) {
  .inquiry-shell { grid-template-columns: 1fr; }
  .inquiry-side { position: static; order: 2; max-width: 720px; margin: var(--sp-9) auto 0; }
  .inquiry-form { padding: var(--sp-7) var(--sp-6); }
  .inquiry-hero-trust { grid-template-columns: 1fr; gap: 0; padding: 0; border: none; }
  .inquiry-trust-item { border-right: none; border-bottom: 1px solid rgba(226,199,154,0.22); padding: var(--sp-3) 0; }
  .inquiry-trust-item:last-child { border-bottom: none; }
}
@media (max-width: 640px) {
  .inquiry-form { padding: var(--sp-6) var(--sp-4); }
  .inquiry-form::before { inset: 6px; }
  .inquiry-submit, .inquiry-form .submit-btn { width: 100%; min-width: 0; padding: 20px var(--sp-5); font-size: 14px; letter-spacing: 0.22em; }
  .inquiry-form .field { margin-bottom: var(--sp-6); }
}

/* =============================================================================
   Refined Thank-You Page (override old brand-* tokens)
   ============================================================================= */
.thank-section {
  background: linear-gradient(180deg, var(--cream) 0%, var(--paper) 100%) !important;
  padding: clamp(80px, 10vw, 140px) var(--sp-7) !important;
}
.thank-check {
  width: 88px !important;
  height: 88px !important;
  background: linear-gradient(135deg, var(--gold-light), var(--gold-deep)) !important;
  box-shadow:
    0 0 0 8px rgba(176, 136, 85, 0.10),
    0 0 0 18px rgba(176, 136, 85, 0.05),
    0 18px 40px -8px rgba(176, 136, 85, 0.5) !important;
  position: relative;
  animation: thankPulse 2.4s ease-in-out infinite;
}
@keyframes thankPulse {
  0%, 100% { box-shadow: 0 0 0 8px rgba(176, 136, 85, 0.10), 0 0 0 18px rgba(176, 136, 85, 0.05), 0 18px 40px -8px rgba(176, 136, 85, 0.5); }
  50% { box-shadow: 0 0 0 14px rgba(176, 136, 85, 0.06), 0 0 0 26px rgba(176, 136, 85, 0.02), 0 22px 48px -8px rgba(176, 136, 85, 0.6); }
}
.thank-check svg { stroke: var(--paper) !important; }
.thank-en {
  font-family: var(--serif-en) !important;
  font-style: italic !important;
  font-weight: 500 !important;
  color: var(--gold-deep) !important;
  letter-spacing: 0.4em !important;
  font-size: 12px !important;
}
.thank-h {
  font-family: var(--mincho-display) !important;
  font-weight: 500 !important;
  color: var(--ink-deep) !important;
  letter-spacing: 0.06em !important;
}
.thank-h em {
  background: linear-gradient(90deg, var(--gold-deep), var(--gold), var(--gold-bright));
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  color: transparent !important;
  font-weight: 600 !important;
}
.thank-lead {
  font-family: var(--mincho) !important;
  color: var(--text) !important;
  line-height: 2.1 !important;
  letter-spacing: 0.06em !important;
}
.thank-lead strong { color: var(--ink-deep) !important; font-weight: 600 !important; }

/* Thank-you timeline */
.thank-timeline {
  max-width: 720px;
  margin: var(--sp-9) auto 0;
  padding: var(--sp-7) var(--sp-6);
  background: var(--white);
  border: 1px solid var(--line-soft);
  position: relative;
  text-align: left;
}
.thank-timeline::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}
.thank-timeline-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-weight: 500;
  font-size: 11px;
  color: var(--gold-deep);
  letter-spacing: 0.4em;
  text-align: center;
  margin-bottom: var(--sp-3);
  position: relative;
}
.thank-timeline-h {
  font-family: var(--mincho-display);
  font-size: 20px;
  color: var(--ink-deep);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-align: center;
  margin-bottom: var(--sp-7);
  position: relative;
}
.thank-timeline-list { list-style: none; padding: 0; counter-reset: tl; position: relative; }
.thank-timeline-list li {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: var(--sp-4);
  padding: var(--sp-4) 0;
  border-bottom: 1px dashed var(--line-soft);
  position: relative;
}
.thank-timeline-list li:last-child { border-bottom: none; }
.thank-timeline-list li:not(:last-child)::after {
  content: "";
  position: absolute;
  left: 27px;
  top: 56px;
  bottom: -8px;
  width: 1px;
  background: linear-gradient(to bottom, var(--gold-light), transparent);
}
.thank-tl-num {
  width: 56px;
  height: 56px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  background: var(--white);
  position: relative;
  z-index: 1;
}
.thank-tl-num small {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 9.5px;
  color: var(--gold-deep);
  letter-spacing: 0.18em;
  font-weight: 500;
}
.thank-tl-num strong {
  font-family: var(--mincho-display);
  font-size: 16px;
  color: var(--gold-deep);
  font-weight: 600;
  letter-spacing: 0.04em;
}
.thank-tl-h {
  font-family: var(--mincho);
  font-size: 14.5px;
  color: var(--ink-deep);
  font-weight: 600;
  letter-spacing: 0.08em;
  margin-bottom: 4px;
}
.thank-tl-p {
  font-family: var(--mincho);
  font-size: 12.5px;
  color: var(--text-soft);
  line-height: 1.95;
  letter-spacing: 0.04em;
}

/* Thank-you next-steps refined */
.next-steps {
  border-top: 1px solid var(--line-soft) !important;
  padding-top: var(--sp-9) !important;
}
.next-steps-label {
  font-family: var(--serif-en) !important;
  font-style: italic !important;
  color: var(--gold-deep) !important;
  font-weight: 500 !important;
  letter-spacing: 0.4em !important;
  font-size: 11px !important;
}
.next-steps-h {
  font-family: var(--mincho-display) !important;
  color: var(--ink-deep) !important;
  font-weight: 500 !important;
  letter-spacing: 0.06em !important;
}
.next-card {
  background: var(--white) !important;
  border: 1px solid var(--line-soft) !important;
  border-left: 2px solid var(--gold) !important;
  padding: var(--sp-7) !important;
  position: relative;
  transition: var(--t) !important;
}
.next-card::before {
  content: "";
  position: absolute;
  inset: 6px;
  border: 1px solid transparent;
  pointer-events: none;
  transition: border-color 0.3s ease;
}
.next-card:hover {
  background: var(--cream) !important;
  border-left-color: var(--gold-deep) !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 28px 48px -16px rgba(10, 23, 41, 0.12) !important;
}
.next-card:hover::before { border-color: var(--gold-light); }
.next-num {
  font-family: var(--serif-en) !important;
  font-style: italic !important;
  color: var(--gold-deep) !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em !important;
}
.next-title {
  font-family: var(--mincho) !important;
  color: var(--ink-deep) !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
}
.next-desc {
  font-family: var(--mincho) !important;
  color: var(--text-soft) !important;
  line-height: 2 !important;
  letter-spacing: 0.04em !important;
}
.next-link {
  font-family: var(--mincho) !important;
  color: var(--gold-deep) !important;
  font-weight: 600 !important;
  letter-spacing: 0.12em !important;
  font-size: 12.5px !important;
}
.next-link:hover { color: var(--ink-deep) !important; }

.thank-contact { border-top: 1px solid var(--line-soft) !important; }
.thank-contact-label {
  font-family: var(--serif-en) !important;
  font-style: italic !important;
  color: var(--gold-deep) !important;
  font-weight: 500 !important;
  letter-spacing: 0.4em !important;
  font-size: 11px !important;
}
.thank-contact-tel {
  font-family: var(--mincho-display) !important;
  color: var(--ink-deep) !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
}
.thank-contact-hours {
  font-family: var(--mincho) !important;
  color: var(--text-soft) !important;
  letter-spacing: 0.18em !important;
}

/* CSSEOF */

/* =============================================================================
   Two Paths Section — 相続 + ROA → 商談のテーブル
   ============================================================================= */
.two-paths-section { background: linear-gradient(180deg, var(--cream) 0%, var(--paper) 100%); }
.two-paths-wrap {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(24px, 3vw, 40px);
  position: relative;
}
.two-paths-wrap::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1px;
  height: 60%;
  background: linear-gradient(to bottom, transparent, var(--gold-light) 30%, var(--gold-light) 70%, transparent);
  pointer-events: none;
  z-index: 0;
}
@media (max-width: 980px) {
  .two-paths-wrap { grid-template-columns: 1fr; }
  .two-paths-wrap::before { display: none; }
}

.path-card {
  background: var(--white);
  border: 1px solid var(--line);
  padding: clamp(28px, 3.5vw, 48px);
  position: relative;
  display: flex;
  flex-direction: column;
  z-index: 1;
  transition: var(--t);
}
.path-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
  transition: border-color 0.3s ease;
}
.path-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 32px 64px -16px rgba(10, 23, 41, 0.18);
}
.path-card:hover::before { border-color: var(--gold-light); }

.path-card-inheritance { background: linear-gradient(180deg, var(--paper-warm) 0%, var(--cream) 100%); }
.path-card-roa { background: linear-gradient(180deg, var(--white) 0%, var(--cream) 100%); border-top: 3px solid var(--gold); }
.path-card-inheritance { border-top: 3px solid var(--accent-vermillion); }

.path-card-head { margin-bottom: var(--sp-6); }
.path-card-meta {
  font-family: var(--serif-en);
  font-style: italic;
  font-weight: 500;
  font-size: 11px;
  color: var(--gold-deep);
  letter-spacing: 0.4em;
  margin-bottom: var(--sp-3);
}
.path-card-inheritance .path-card-meta { color: var(--accent-vermillion-dark); }
.path-card-h {
  font-family: var(--mincho-display);
  font-size: clamp(24px, 2.6vw, 32px);
  color: var(--ink-deep);
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.5;
  margin-bottom: var(--sp-3);
}
.path-card-h em {
  font-style: normal;
  background: linear-gradient(90deg, var(--gold-deep), var(--gold), var(--gold-bright));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.path-card-inheritance .path-card-h em {
  background: linear-gradient(90deg, var(--accent-vermillion-dark), var(--accent-vermillion));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.path-card-sub {
  font-family: var(--mincho);
  font-size: 13.5px;
  color: var(--text-soft);
  line-height: 2;
  letter-spacing: 0.06em;
}

.path-mini-row {
  display: grid;
  grid-template-columns: 1fr 32px 1fr;
  gap: var(--sp-3);
  align-items: stretch;
  margin: var(--sp-6) 0;
  padding: var(--sp-5) 0;
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
}
.path-mini-col { text-align: center; padding: 0 var(--sp-3); }
.path-mini-col.after .path-mini-stat {
  background: linear-gradient(90deg, var(--gold-deep), var(--gold), var(--gold-bright));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.path-card-inheritance .path-mini-col.after .path-mini-stat {
  background: linear-gradient(90deg, var(--accent-vermillion-dark), var(--accent-vermillion));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.path-mini-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-weight: 500;
  font-size: 10.5px;
  color: var(--text-soft);
  letter-spacing: 0.32em;
  margin-bottom: var(--sp-2);
}
.path-mini-stat {
  font-family: var(--mincho-display);
  font-size: clamp(32px, 4vw, 44px);
  color: var(--ink-deep);
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.02em;
  margin-bottom: 6px;
}
.path-mini-stat small {
  font-family: var(--mincho);
  font-size: 0.4em;
  font-weight: 400;
  letter-spacing: 0.15em;
  margin-left: 3px;
  color: var(--text);
  -webkit-text-fill-color: currentColor;
}
.path-mini-cap {
  font-family: var(--mincho);
  font-size: 11.5px;
  color: var(--text-soft);
  letter-spacing: 0.06em;
  line-height: 1.6;
}
.path-mini-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 22px;
  color: var(--gold);
  font-weight: 500;
}

.path-desc {
  font-family: var(--mincho);
  font-size: 13.5px;
  color: var(--text);
  line-height: 2.1;
  letter-spacing: 0.04em;
  margin-bottom: var(--sp-6);
  flex-grow: 1;
}
.path-desc strong { color: var(--ink-deep); font-weight: 600; }
.path-desc small {
  display: block;
  font-size: 10.5px;
  color: var(--text-light);
  margin-top: var(--sp-2);
  letter-spacing: 0.08em;
  font-style: italic;
}

.path-card-cta {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  padding-top: var(--sp-5);
  border-top: 1px dashed var(--line-soft);
}
.path-card-cta .btn { justify-content: center; }
/* 相続/投資カードの主要CTA: グローバル .btn-gold が薄い背景で不可視化されるため、
   2クラス指定で確実に見えるゴールド塗りつぶしへ上書き（このセクション限定） */
.path-card-cta .path-card-primary {
  font-weight: 700;
  background: linear-gradient(135deg, var(--gold-bright) 0%, var(--gold) 50%, var(--gold-deep) 100%);
  color: var(--ink-deep);
  border: 1px solid var(--gold-deep);
  box-shadow: 0 12px 36px rgba(130, 99, 53, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.3);
}
.path-card-cta .path-card-primary:hover {
  color: var(--ink-deep);
  transform: translateY(-2px);
  box-shadow: 0 18px 48px rgba(130, 99, 53, 0.45), inset 0 1px 0 rgba(255, 255, 255, 0.4);
}

/* Foot */
.two-paths-foot {
  max-width: 880px;
  margin: clamp(48px, 6vw, 80px) auto 0;
  text-align: center;
  position: relative;
}
.two-paths-foot-line {
  width: 60px;
  height: 1px;
  background: var(--gold);
  margin: 0 auto var(--sp-6);
}
.two-paths-foot-txt {
  font-family: var(--mincho);
  font-size: 15px;
  color: var(--text);
  line-height: 2.2;
  letter-spacing: 0.08em;
  margin-bottom: var(--sp-6);
}
.two-paths-foot-txt em {
  font-style: normal;
  color: var(--gold-deep);
  font-weight: 600;
  border-bottom: 1px solid var(--gold-light);
  padding-bottom: 2px;
}

/* CSSEOF */

/* CSSEOF */


/* ============================================================
   ENHANCED ANIMATIONS — Site-Wide Polish (2026-05)
   ============================================================ */

/* 1. LINE float button — gentle attention pulse */
@keyframes lineGentlePulse {
  0%, 100% { box-shadow: 0 8px 24px rgba(6, 199, 85, 0.32), 0 0 0 0 rgba(6, 199, 85, 0); }
  50%      { box-shadow: 0 12px 30px rgba(6, 199, 85, 0.42), 0 0 0 12px rgba(6, 199, 85, 0); }
}
.line-fixed {
  animation: lineGentlePulse 3.2s ease-in-out infinite;
  transition: transform 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.line-fixed:hover { transform: translateY(-3px) scale(1.04); animation-play-state: paused; }

/* 2. Section heading "shine sweep" on reveal */
@keyframes shineSweep {
  0%   { background-position: 200% 0; }
  60%  { background-position: -50% 0; }
  100% { background-position: -50% 0; }
}
.reveal.is-visible .section-title em,
.reveal.is-visible .ceo-trust-h em,
.reveal.is-visible .usp-title em,
.reveal.is-visible .onestop-title em,
.reveal.is-visible h1 em {
  background-image: linear-gradient(90deg,
    rgba(176, 136, 85, 0.18) 0%,
    rgba(176, 136, 85, 0.18) 40%,
    rgba(255, 215, 100, 0.45) 50%,
    rgba(176, 136, 85, 0.18) 60%,
    rgba(176, 136, 85, 0.18) 100%);
  background-size: 220% 100%;
  background-position: 200% 0;
  animation: shineSweep 1.6s ease-out 0.4s 1 forwards;
}

/* 3. Primary CTA button — subtle inner glow on hover */
.btn-primary, .btn-gold {
  position: relative;
  overflow: hidden;
}
.btn-primary::before, .btn-gold::before {
  content: "";
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.22), transparent);
  transition: left 0.65s cubic-bezier(0.22, 0.61, 0.36, 1);
  pointer-events: none;
  z-index: 1;
}
.btn-primary:hover::before, .btn-gold:hover::before {
  left: 100%;
}
.btn-primary > *, .btn-gold > * { position: relative; z-index: 2; }

/* 4. Image hover zoom — uniform across all photo cards */
.area-card-img, .topic-card img, .next-read-card img,
.voice-photo-lg img, .ceo-trust-photo, .ceo-photo {
  transition: transform 0.9s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.area-card:hover .area-card-img,
.topic-card:hover img,
.next-read-card:hover img,
.voice-block:hover .voice-photo-lg img {
  transform: scale(1.06);
}

/* 5. Stagger animations — extend to all grids */
.persona-grid .reveal:nth-child(1) { transition-delay: 0.0s; }
.persona-grid .reveal:nth-child(2) { transition-delay: 0.12s; }
.persona-grid .reveal:nth-child(3) { transition-delay: 0.24s; }

.usp-grid .reveal:nth-child(1) { transition-delay: 0.0s; }
.usp-grid .reveal:nth-child(2) { transition-delay: 0.12s; }
.usp-grid .reveal:nth-child(3) { transition-delay: 0.24s; }

.area-grid .area-card:nth-child(1) { transition-delay: 0.0s; }
.area-grid .area-card:nth-child(2) { transition-delay: 0.08s; }
.area-grid .area-card:nth-child(3) { transition-delay: 0.16s; }
.area-grid .area-card:nth-child(4) { transition-delay: 0.24s; }
.area-grid .area-card:nth-child(5) { transition-delay: 0.32s; }
.area-grid .area-card:nth-child(6) { transition-delay: 0.4s; }
.area-grid .area-card:nth-child(7) { transition-delay: 0.48s; }

.ward-map-grid .ward-card:nth-child(1) { transition-delay: 0s; }
.ward-map-grid .ward-card:nth-child(2) { transition-delay: 0.05s; }
.ward-map-grid .ward-card:nth-child(3) { transition-delay: 0.1s; }
.ward-map-grid .ward-card:nth-child(4) { transition-delay: 0.15s; }
.ward-map-grid .ward-card:nth-child(5) { transition-delay: 0.2s; }
.ward-map-grid .ward-card:nth-child(6) { transition-delay: 0.25s; }
.ward-map-grid .ward-card:nth-child(7) { transition-delay: 0.3s; }

.onestop-grid .onestop-item:nth-child(1) { transition-delay: 0s; }
.onestop-grid .onestop-item:nth-child(2) { transition-delay: 0.06s; }
.onestop-grid .onestop-item:nth-child(3) { transition-delay: 0.12s; }
.onestop-grid .onestop-item:nth-child(4) { transition-delay: 0.18s; }
.onestop-grid .onestop-item:nth-child(5) { transition-delay: 0.24s; }
.onestop-grid .onestop-item:nth-child(6) { transition-delay: 0.3s; }
.onestop-grid .onestop-item:nth-child(7) { transition-delay: 0.36s; }
.onestop-grid .onestop-item:nth-child(8) { transition-delay: 0.42s; }

.voices-grid .voice-card:nth-child(1) { transition-delay: 0s; }
.voices-grid .voice-card:nth-child(2) { transition-delay: 0.1s; }
.voices-grid .voice-card:nth-child(3) { transition-delay: 0.2s; }
.voices-grid .voice-card:nth-child(4) { transition-delay: 0.3s; }

.inh-pain-grid .inh-pain-card:nth-child(1) { transition-delay: 0s; }
.inh-pain-grid .inh-pain-card:nth-child(2) { transition-delay: 0.08s; }
.inh-pain-grid .inh-pain-card:nth-child(3) { transition-delay: 0.16s; }
.inh-pain-grid .inh-pain-card:nth-child(4) { transition-delay: 0.24s; }
.inh-pain-grid .inh-pain-card:nth-child(5) { transition-delay: 0.32s; }
.inh-pain-grid .inh-pain-card:nth-child(6) { transition-delay: 0.4s; }

.inh-risk-grid .inh-risk-card:nth-child(1) { transition-delay: 0s; }
.inh-risk-grid .inh-risk-card:nth-child(2) { transition-delay: 0.12s; }
.inh-risk-grid .inh-risk-card:nth-child(3) { transition-delay: 0.24s; }

.inh-why-grid .inh-why-card:nth-child(1) { transition-delay: 0s; }
.inh-why-grid .inh-why-card:nth-child(2) { transition-delay: 0.12s; }
.inh-why-grid .inh-why-card:nth-child(3) { transition-delay: 0.24s; }

/* 6. Hero stats — slide in from right */
@keyframes heroStatsSlide {
  from { opacity: 0; transform: translateX(30px); }
  to   { opacity: 1; transform: translateX(0); }
}
.hero-stats {
  animation: heroStatsSlide 1.1s cubic-bezier(0.16, 1, 0.3, 1) 0.5s both;
}

/* 7. Sticky CTA bar — slide-up entrance */
@keyframes stickyBarSlideUp {
  from { transform: translateY(100%); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
.sticky-cta {
  animation: stickyBarSlideUp 0.5s cubic-bezier(0.16, 1, 0.3, 1) both;
}

/* 8. Number count-up scale punch */
@keyframes numberPunch {
  0%   { transform: scale(0.94); opacity: 0; }
  60%  { transform: scale(1.04); }
  100% { transform: scale(1); opacity: 1; }
}
.reveal.is-visible .big-number-value,
.reveal.is-visible .hero-stat-value,
.reveal.is-visible .onestop-stat-num {
  animation: numberPunch 1.0s cubic-bezier(0.34, 1.56, 0.64, 1) 0.3s both;
}

/* 9. Bar chart fill — animate width on reveal */
.reveal.is-visible .chart-bar,
.reveal.is-visible .bar-fill {
  animation: barGrow 1.4s cubic-bezier(0.16, 1, 0.3, 1) 0.4s both;
}
@keyframes barGrow {
  from { transform: scaleY(0); transform-origin: bottom; }
  to   { transform: scaleY(1); transform-origin: bottom; }
}
.bar-track .bar-fill {
  animation: none;
}
.reveal.is-visible .bar-track .bar-fill {
  animation: barFill 1.4s cubic-bezier(0.16, 1, 0.3, 1) 0.4s both;
  transform-origin: left;
}
@keyframes barFill {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

/* 10. Subtle parallax-like effect for hero background (purely CSS) */
.hero::before {
  transition: transform 1.5s cubic-bezier(0.22, 0.61, 0.36, 1);
  will-change: transform;
}
.is-scrolled .hero::before {
  transform: scale(1.04) translateY(-2%);
}

/* 11. Anchor link smooth float on hover */
a:not(.btn):not(.tool-card):not(.area-card):not(.topic-card):not(.next-read-card):not(.temp-cta-card):not(.voice-card):not(.persona-card):not(.usp-card):not(.ward-card):not(.subtopic-card):not(.line-fixed) {
  transition: color 0.3s ease, opacity 0.3s ease;
}

/* 12. Footer logo — gentle hover lift */
.footer-logo-img { transition: transform 0.5s cubic-bezier(0.22, 0.61, 0.36, 1), filter 0.4s ease; }
.site-footer:hover .footer-logo-img { transform: translateY(-2px); }

/* 13. Header logo — gentle hover */
.logo-img { transition: transform 0.4s cubic-bezier(0.22, 0.61, 0.36, 1); }
.logo:hover .logo-img { transform: scale(1.03); }

/* 14. Final CTA breathing background */
@keyframes ctaBreath {
  0%, 100% { background-position: 0% 50%; }
  50%      { background-position: 100% 50%; }
}
.final-cta::before, .inh-final-cta::before {
  background-size: 200% 200%;
  animation: ctaBreath 8s ease-in-out infinite;
}

/* 15. Form field focus animations (gentle) */
.field input:focus, .field textarea:focus, .field select:focus {
  transition: border-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
}

/* 16. Header is-scrolled state — smoother backdrop */
.site-header.is-scrolled {
  backdrop-filter: blur(20px) saturate(170%);
  -webkit-backdrop-filter: blur(20px) saturate(170%);
}

/* Reduced motion — respect user preference */
@media (prefers-reduced-motion: reduce) {
  .line-fixed { animation: none; }
  .reveal.is-visible .section-title em,
  .reveal.is-visible .ceo-trust-h em,
  .reveal.is-visible .usp-title em,
  .reveal.is-visible .onestop-title em,
  .reveal.is-visible h1 em { animation: none; background: none; }
  .btn-primary::before, .btn-gold::before { display: none; }
  .reveal.is-visible .big-number-value,
  .reveal.is-visible .hero-stat-value,
  .reveal.is-visible .onestop-stat-num { animation: none; }
  .reveal.is-visible .chart-bar,
  .reveal.is-visible .bar-fill,
  .reveal.is-visible .bar-track .bar-fill { animation: none; }
  .final-cta::before, .inh-final-cta::before { animation: none; }
  .hero::before { transition: none; transform: none !important; }
  .sticky-cta { animation: none; }
  .hero-stats { animation: none; }
}

/* ============================================================
   PRINT STYLES — PDF output cleanup for client review
   ============================================================ */
@media print {
  /* Force all scroll-reveal elements to be fully visible */
  .reveal,
  .reveal.is-visible,
  .field.reveal,
  .inquiry-side-block.reveal,
  body.form-page .reveal {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    animation: none !important;
    transition: none !important;
  }

  /* Hide fixed / sticky overlays that obscure content in print */
  .line-fixed,
  .sticky-cta,
  .bottom-cta-bar,
  .reading-progress,
  .fab-stack,
  .fab,
  a.line-fixed { display: none !important; }

  /* Make sticky header static so it doesn't overlap content */
  .site-header {
    position: static !important;
    transform: none !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    background: var(--paper) !important;
  }

  /* Ensure all decorative animations stop */
  *,
  *::before,
  *::after {
    animation-duration: 0s !important;
    animation-delay: 0s !important;
    transition-duration: 0s !important;
    transition-delay: 0s !important;
  }

  /* Avoid awkward page breaks inside cards */
  .voice-block,
  .voice-card,
  .area-card,
  .tool-card,
  .topic-card,
  .next-read-card,
  .temp-cta-card,
  .persona-card,
  .pillar-card,
  .usp-card,
  .strength-card,
  .concern-item,
  .ceo-trust,
  .ceo-section,
  .inh-pain-card,
  .inh-risk-card,
  .inh-why-card,
  .inh-approach-card,
  .inh-process-item,
  .inh-kb-item,
  .sale-flow-item,
  .case-detail-block,
  .failure-item {
    page-break-inside: avoid;
    break-inside: avoid;
  }

  /* Ensure section transitions break nicely */
  section { page-break-inside: auto; }
  h1, h2 { page-break-after: avoid; break-after: avoid; }

  /* Force image quality */
  img { max-width: 100%; height: auto; }

  /* Hide LINE green button if any escaped */
  [class*="line-fixed"],
  [href*="line"] { display: none !important; }

  /* Background colors / images should print (for design integrity) */
  * {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    color-adjust: exact !important;
  }

  /* Hero / Final CTA — ensure backgrounds show */
  .hero, .hero::before, .final-cta, .inh-final-cta, .ceo-section,
  .inh-risk-section, .inh-ceo-section {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
}

/* ============================================
   Mobile Drawer / Hamburger Menu (v2.1.0+)
   ============================================ */

/* Hamburger toggle button - hidden on desktop */
.mobile-toggle {
  display: none;
  background: none;
  border: 0;
  cursor: pointer;
  width: 44px;
  height: 44px;
  padding: 0;
  position: relative;
  margin-left: var(--sp-3);
  z-index: 1101;
}
.mobile-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--ink-deep);
  margin: 5px auto;
  transition: var(--t);
}
body.drawer-open .mobile-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
body.drawer-open .mobile-toggle span:nth-child(2) { opacity: 0; }
body.drawer-open .mobile-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Drawer (off-canvas) - hidden on desktop */
.mobile-drawer {
  display: none;
  position: fixed;
  top: 0;
  right: -100%;
  width: min(86vw, 380px);
  height: 100vh;
  background: var(--paper);
  z-index: 1100;
  transition: right 0.32s cubic-bezier(0.22, 0.61, 0.36, 1);
  overflow-y: auto;
  box-shadow: -10px 0 40px rgba(10, 23, 41, 0.18);
  padding: calc(var(--sp-8) + 60px) var(--sp-7) var(--sp-7);
}
body.drawer-open .mobile-drawer {
  right: 0;
}

.mobile-nav {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--line-soft);
}
.mobile-nav a {
  display: block;
  padding: 18px 0;
  font-family: var(--mincho);
  font-size: 16px;
  color: var(--ink-deep);
  border-bottom: 1px solid var(--line-soft);
  letter-spacing: 0.08em;
  text-decoration: none;
  transition: color var(--t);
}
.mobile-nav a:hover {
  color: var(--gold-deep);
}

.mobile-drawer-cta {
  margin-top: var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--line-soft);
}
.mobile-drawer-tel {
  display: block;
  text-align: center;
  text-decoration: none;
  padding: var(--sp-4);
  background: var(--cream);
  border: 1px solid var(--gold-light);
}
.md-tel-label {
  display: block;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold-deep);
  letter-spacing: 0.3em;
  margin-bottom: 4px;
}
.md-tel-num {
  display: block;
  font-family: var(--serif-en);
  font-size: 24px;
  color: var(--ink-deep);
  font-weight: 500;
  letter-spacing: 0.04em;
}
.md-tel-hours {
  display: block;
  font-family: var(--mincho);
  font-size: 11px;
  color: var(--text-soft);
  margin-top: 4px;
}
.mobile-drawer-btn {
  width: 100%;
  text-align: center;
}

/* Overlay */
.mobile-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(10, 23, 41, 0.5);
  z-index: 1099;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}
body.drawer-open .mobile-overlay {
  opacity: 1;
  pointer-events: auto;
}

/* Show mobile UI on mobile devices */
@media (max-width: 980px) {
  .mobile-toggle { display: block; }
  .mobile-drawer { display: block; }
  .mobile-overlay { display: block; }
  /* Hide desktop nav on mobile */
  .global-nav { display: none; }
  .header-right .header-phone { display: none; }
  .header-right .btn-primary { display: none; }
}

/* Prevent body scroll when drawer open */
body.drawer-open {
  overflow: hidden;
}

/* ============================================
   Article / Blog Post Styles (v2.1.0+)
   ライターが HTML を貼るだけで統一デザインになる
   ============================================ */

/* === Article wrapper === */
.article-wrap {
  max-width: 820px;
  margin: var(--sp-7) auto var(--sp-9);
  padding: 0 var(--sp-6);
}

/* === Article meta (cat / date / author) === */
.article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
  align-items: center;
  font-family: var(--mincho);
  font-size: 12.5px;
  color: var(--text-soft);
  letter-spacing: 0.08em;
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-5);
  border-bottom: 1px solid var(--line-soft);
}
.article-cat {
  display: inline-block;
  padding: 4px 12px;
  background: var(--cream);
  border: 1px solid var(--gold-light);
  color: var(--gold-deep);
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11.5px;
  letter-spacing: 0.18em;
}
.article-date, .article-author { font-size: 12.5px; }

/* === Article H1 (title) === */
.article-h1 {
  font-family: var(--mincho-display);
  font-size: clamp(28px, 4vw, 42px);
  line-height: 1.45;
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.03em;
  margin: 0 0 var(--sp-7);
}

/* === TL;DR Summary box === */
.article-tldr {
  background: var(--cream);
  border: 1px solid var(--gold-light);
  border-left: 4px solid var(--gold);
  padding: var(--sp-6) var(--sp-6);
  margin: var(--sp-7) 0;
}
.article-tldr-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold-deep);
  letter-spacing: 0.35em;
  margin-bottom: var(--sp-3);
}
.article-tldr ul,
.article-tldr ol {
  margin: 0;
  padding-left: var(--sp-5);
}
.article-tldr li {
  font-family: var(--mincho);
  font-size: 14.5px;
  line-height: 2.0;
  color: var(--ink-deep);
  margin-bottom: 6px;
  letter-spacing: 0.04em;
}

/* === Table of Contents === */
.article-toc {
  background: var(--paper);
  border: 1px solid var(--line);
  padding: var(--sp-5) var(--sp-6);
  margin: var(--sp-7) 0;
}
.article-toc-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold-deep);
  letter-spacing: 0.35em;
  margin-bottom: var(--sp-3);
}
.article-toc ol,
.article-toc ul {
  margin: 0;
  padding-left: var(--sp-5);
  font-family: var(--mincho);
  font-size: 14px;
  line-height: 2.1;
  color: var(--ink-deep);
}
.article-toc a {
  color: var(--ink-deep);
  text-decoration: none;
  border-bottom: 1px dashed transparent;
  transition: var(--t);
}
.article-toc a:hover {
  border-bottom-color: var(--gold);
  color: var(--gold-deep);
}

/* === Article H2 (section heading) === */
.article-h2 {
  font-family: var(--mincho-display);
  font-size: clamp(22px, 2.4vw, 28px);
  line-height: 1.5;
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  padding: var(--sp-3) 0 var(--sp-3) var(--sp-4);
  border-left: 5px solid var(--gold);
  margin: var(--sp-9) 0 var(--sp-5);
  background: linear-gradient(to right, rgba(226, 199, 154, 0.08), transparent);
}

/* === Article H3 === */
.article-h3 {
  font-family: var(--mincho-display);
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  margin: var(--sp-7) 0 var(--sp-4);
  padding-bottom: 8px;
  border-bottom: 1px solid var(--gold-light);
}

/* === Article H4 === */
.article-h4 {
  font-family: var(--mincho-display);
  font-size: clamp(16px, 1.7vw, 19px);
  font-weight: 600;
  color: var(--gold-deep);
  letter-spacing: 0.04em;
  margin: var(--sp-6) 0 var(--sp-3);
}

/* === Article paragraph === */
.article-p,
.aspartner-article p {
  font-family: var(--mincho);
  font-size: 15.5px;
  line-height: 2.05;
  color: var(--text);
  letter-spacing: 0.05em;
  margin: 0 0 var(--sp-4);
}
.article-p strong,
.aspartner-article strong {
  color: var(--gold-deep);
  font-weight: 600;
}
.article-p a,
.aspartner-article a {
  color: var(--gold-deep);
  text-decoration: none;
  border-bottom: 1px solid var(--gold-light);
  transition: var(--t);
}
.article-p a:hover,
.aspartner-article a:hover {
  border-bottom-color: var(--gold);
  background: rgba(226, 199, 154, 0.1);
}

/* === Article lists === */
.article-ul,
.article-ol,
.aspartner-article ul,
.aspartner-article ol {
  font-family: var(--mincho);
  font-size: 15px;
  line-height: 2.0;
  color: var(--text);
  margin: var(--sp-4) 0;
  padding-left: var(--sp-6);
  letter-spacing: 0.05em;
}
.article-ul li,
.article-ol li,
.aspartner-article li {
  margin-bottom: 8px;
}
.article-ul li::marker,
.aspartner-article ul li::marker {
  color: var(--gold);
}

/* === Article blockquote === */
.article-quote,
.aspartner-article blockquote {
  font-family: var(--mincho);
  font-size: 15px;
  line-height: 2.0;
  color: var(--text-mid);
  font-style: italic;
  padding: var(--sp-4) var(--sp-5);
  margin: var(--sp-5) 0;
  background: var(--cream);
  border-left: 4px solid var(--gold);
  letter-spacing: 0.05em;
}

/* === Article table === */
.article-table,
.aspartner-article table,
.article-wrap table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--sp-5) 0;
  font-family: var(--mincho);
  font-size: 14px;
}
.article-table th,
.aspartner-article th,
.article-wrap th {
  background: var(--ink-deep);
  color: var(--paper);
  font-weight: 500;
  padding: 12px var(--sp-4);
  text-align: left;
  letter-spacing: 0.08em;
  font-size: 12.5px;
}
.article-table td,
.aspartner-article td,
.article-wrap td {
  padding: 12px var(--sp-4);
  border-bottom: 1px solid var(--line-soft);
  color: var(--text);
  line-height: 1.8;
  vertical-align: top;
}
.article-table tr:nth-child(even) td,
.aspartner-article tr:nth-child(even) td,
.article-wrap tr:nth-child(even) td {
  background: var(--cream);
}

/* === Article image === */
.article-img,
.aspartner-article img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: var(--sp-6) auto;
  border-radius: 2px;
  box-shadow: 0 8px 24px rgba(10, 23, 41, 0.08);
}
.article-figcaption,
.aspartner-article figcaption {
  text-align: center;
  font-family: var(--mincho);
  font-size: 12px;
  color: var(--text-soft);
  margin-top: -var(--sp-3);
  margin-bottom: var(--sp-6);
  letter-spacing: 0.06em;
}

/* === Callout boxes (highlight / warning / success / info) === */
.callout {
  padding: var(--sp-5) var(--sp-6);
  margin: var(--sp-5) 0;
  border-radius: 2px;
  font-family: var(--mincho);
  font-size: 14.5px;
  line-height: 1.95;
  letter-spacing: 0.04em;
}
.callout h4 {
  font-family: var(--mincho-display);
  font-size: 17px;
  margin: 0 0 var(--sp-3);
  font-weight: 600;
}
.callout p { margin: 0 0 8px; }
.callout p:last-child { margin-bottom: 0; }

.callout-highlight {
  background: var(--cream);
  border-left: 4px solid var(--gold);
  color: var(--ink-deep);
}
.callout-highlight h4 { color: var(--gold-deep); }

.callout-warning {
  background: #fbf5ea;
  border-left: 4px solid #c89b50;
  color: var(--ink-deep);
}
.callout-warning h4 { color: #8a6020; }

.callout-info {
  background: rgba(226, 199, 154, 0.10);
  border: 1px solid var(--gold-light);
  color: var(--text);
}
.callout-info h4 { color: var(--gold-deep); }

/* === In-article CTA (most important for conversions) === */
.callout-cta {
  padding: var(--sp-6) var(--sp-6);
  margin: var(--sp-7) 0;
  background: linear-gradient(135deg, var(--ink-deep) 0%, var(--ink) 100%);
  color: var(--paper);
  text-align: center;
}
.callout-cta h4 {
  font-family: var(--mincho-display);
  font-size: clamp(18px, 2vw, 22px);
  color: var(--gold-bright);
  margin: 0 0 var(--sp-3);
  font-weight: 600;
  letter-spacing: 0.06em;
}
.callout-cta p {
  color: rgba(250, 247, 240, 0.86);
  margin: 0 0 var(--sp-4);
  font-size: 14px;
  line-height: 1.9;
}
.callout-cta .btn {
  display: inline-block;
  margin-top: var(--sp-2);
}
/* 記事→問い合わせ導線: 濃紺ボックス内のCTAボタンが薄くて見えない問題を修正。
   ゴールド塗りつぶし＋ネイビー文字で、暗い背景上でも明確に目立たせる */
.callout-cta .btn-gold {
  background: linear-gradient(135deg, var(--gold-bright) 0%, var(--gold) 50%, var(--gold-deep) 100%);
  color: var(--ink-deep);
  border: 1px solid var(--gold-bright);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.35);
}
.callout-cta .btn-gold:hover {
  color: var(--ink-deep);
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.45);
}

/* (premium final-cta block removed — unused; templates use full-width .final-cta) */

/* === Checklist === */
.article-checklist {
  list-style: none;
  padding: 0;
  margin: var(--sp-5) 0;
}
.article-checklist li {
  font-family: var(--mincho);
  font-size: 14.5px;
  line-height: 1.85;
  color: var(--ink-deep);
  padding: 10px 0 10px 32px;
  position: relative;
  border-bottom: 1px solid var(--line-soft);
  letter-spacing: 0.04em;
}
.article-checklist li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 10px;
  width: 22px;
  height: 22px;
  background: var(--gold);
  color: var(--paper);
  font-weight: 700;
  text-align: center;
  line-height: 22px;
  border-radius: 2px;
  font-size: 13px;
}

/* === FAQ === */
.article-faq {
  margin: var(--sp-5) 0;
}
.article-faq-item {
  border: 1px solid var(--line-soft);
  margin-bottom: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  background: var(--paper);
}
.article-faq-q {
  font-family: var(--mincho-display);
  font-size: 16px;
  font-weight: 600;
  color: var(--ink-deep);
  margin: 0 0 var(--sp-3);
  padding-left: 28px;
  position: relative;
  letter-spacing: 0.04em;
}
.article-faq-q::before {
  content: "Q";
  position: absolute;
  left: 0;
  top: 0;
  width: 22px;
  height: 22px;
  background: var(--gold);
  color: var(--paper);
  font-family: var(--serif-en);
  font-size: 13px;
  font-weight: 700;
  text-align: center;
  line-height: 22px;
  border-radius: 50%;
}
.article-faq-a {
  font-family: var(--mincho);
  font-size: 14.5px;
  line-height: 1.95;
  color: var(--text);
  margin: 0;
  padding-left: 28px;
  position: relative;
  letter-spacing: 0.04em;
}
.article-faq-a::before {
  content: "A";
  position: absolute;
  left: 0;
  top: 0;
  width: 22px;
  height: 22px;
  background: var(--ink-deep);
  color: var(--gold-bright);
  font-family: var(--serif-en);
  font-size: 13px;
  font-weight: 700;
  text-align: center;
  line-height: 22px;
  border-radius: 50%;
}

/* === Source / citation box === */
.article-source {
  margin: var(--sp-6) 0;
  padding: var(--sp-4) var(--sp-5);
  background: var(--cream);
  border-top: 1px solid var(--gold-light);
  border-bottom: 1px solid var(--gold-light);
  font-family: var(--mincho);
  font-size: 12.5px;
  color: var(--text-soft);
  line-height: 1.85;
  letter-spacing: 0.04em;
}
.article-source-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold-deep);
  letter-spacing: 0.35em;
  margin-bottom: 8px;
  display: block;
}
.article-source a {
  color: var(--gold-deep);
}

/* === Stat row (3 columns) === */
.article-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
  margin: var(--sp-6) 0;
  padding: var(--sp-5);
  background: var(--cream);
  border: 1px solid var(--gold-light);
}
.article-stat {
  text-align: center;
}
.article-stat-num {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: clamp(28px, 3.5vw, 40px);
  color: var(--gold-deep);
  font-weight: 500;
  line-height: 1;
}
.article-stat-unit {
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--text);
  margin-left: 4px;
  font-style: normal;
}
.article-stat-label {
  font-family: var(--mincho);
  font-size: 11.5px;
  color: var(--text-soft);
  margin-top: 6px;
  letter-spacing: 0.1em;
}
@media (max-width: 640px) {
  .article-stats { grid-template-columns: 1fr; gap: var(--sp-3); }
}

/* === Author card (bottom of article) === */
.author-card {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: var(--sp-5);
  align-items: start;
  margin: var(--sp-9) 0 0;
  padding: var(--sp-6);
  background: var(--cream);
  border: 1px solid var(--gold-light);
}
.author-photo {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  border: 3px solid var(--paper);
  box-shadow: 0 4px 12px rgba(10, 23, 41, 0.12);
}
.author-name {
  font-family: var(--mincho-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--ink-deep);
  margin-bottom: 4px;
  letter-spacing: 0.04em;
}
.author-role {
  font-family: var(--mincho);
  font-size: 12px;
  color: var(--gold-deep);
  margin-bottom: var(--sp-3);
  letter-spacing: 0.06em;
}
.author-bio {
  font-family: var(--mincho);
  font-size: 13px;
  line-height: 1.95;
  color: var(--text);
  margin: 0;
  letter-spacing: 0.04em;
}
@media (max-width: 640px) {
  .author-card {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .author-photo {
    margin: 0 auto;
  }
}

/* === aspartner-article fallback (when writer uses raw HTML without article-* classes) === */
.aspartner-article {
  font-family: var(--mincho);
  font-size: 15.5px;
  line-height: 2.05;
  color: var(--text);
  letter-spacing: 0.05em;
}
.aspartner-article h1 { font-family: var(--mincho-display); font-size: clamp(26px, 3.5vw, 38px); font-weight: 600; color: var(--ink-deep); margin: var(--sp-7) 0 var(--sp-5); }
.aspartner-article h2 { font-family: var(--mincho-display); font-size: clamp(20px, 2.4vw, 26px); font-weight: 600; color: var(--ink-deep); padding: var(--sp-3) 0 var(--sp-3) var(--sp-4); border-left: 5px solid var(--gold); margin: var(--sp-8) 0 var(--sp-4); background: linear-gradient(to right, rgba(226,199,154,0.08), transparent); letter-spacing: 0.04em; }
.aspartner-article h3 { font-family: var(--mincho-display); font-size: clamp(17px, 2vw, 21px); font-weight: 600; color: var(--ink-deep); margin: var(--sp-6) 0 var(--sp-3); padding-bottom: 6px; border-bottom: 1px solid var(--gold-light); letter-spacing: 0.04em; }
.aspartner-article h4 { font-family: var(--mincho-display); font-size: 17px; color: var(--gold-deep); margin: var(--sp-5) 0 var(--sp-3); font-weight: 600; }

/* === Specificity boost: article-* classes always win when used (mixed-mode safe) === */
.aspartner-article .article-h1,
.aspartner-article .article-h2,
.aspartner-article .article-h3,
.aspartner-article .article-h4,
.aspartner-article .article-p,
.aspartner-article .article-tldr,
.aspartner-article .article-toc,
.aspartner-article .article-stats,
.aspartner-article .article-source,
.aspartner-article .article-checklist,
.aspartner-article .callout-cta {
  /* inherits its own .article-* styles; this rule just raises specificity vs .aspartner-article h2 */
}
.aspartner-article .article-h2 {
  font-size: clamp(22px, 2.4vw, 28px);
  line-height: 1.5;
  margin: var(--sp-9) 0 var(--sp-5);
}
.aspartner-article .article-h3 {
  font-size: clamp(18px, 2vw, 22px);
  margin: var(--sp-7) 0 var(--sp-4);
  padding-bottom: 8px;
}

/* === Reading progress bar === */
.reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 0%;
  height: 3px;
  background: linear-gradient(to right, var(--gold), var(--gold-bright));
  z-index: 1200;
  transition: width 0.1s ease-out;
}


/* ============================================
   Area Page Enhancement (v2.2.0+)
   ============================================ */

/* === Hero meta pills === */
.hero-meta-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: var(--sp-5);
}
.hero-meta-pills .meta-pill {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  background: rgba(226, 199, 154, 0.12);
  border: 1px solid var(--gold-light);
  color: var(--gold-deep);
  font-family: var(--mincho);
  font-size: 12px;
  letter-spacing: 0.08em;
  border-radius: 2px;
}
.hero-meta-pills .meta-pill strong {
  color: var(--gold-deep);
  font-weight: 600;
  margin: 0 3px;
}

/* === Sticky anchor nav === */
.ward-anchor-nav {
  position: sticky;
  top: 70px;
  background: var(--ink-deep);
  color: var(--paper);
  z-index: 90;
  border-bottom: 1px solid var(--gold);
  box-shadow: 0 4px 20px rgba(10, 23, 41, 0.15);
}
.ward-anchor-inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 12px var(--sp-7);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-4);
}
.ward-anchor-label {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold-bright);
  letter-spacing: 0.35em;
  font-weight: 500;
}
.ward-anchor-inner a {
  font-family: var(--mincho);
  font-size: 13px;
  color: rgba(250, 247, 240, 0.85);
  text-decoration: none;
  letter-spacing: 0.06em;
  padding: 4px 12px;
  border: 1px solid transparent;
  transition: var(--t);
}
.ward-anchor-inner a:hover {
  color: var(--gold-bright);
  border-color: var(--gold);
}
@media (max-width: 768px) {
  .ward-anchor-nav { top: 60px; }
  .ward-anchor-inner { padding: 10px var(--sp-4); gap: var(--sp-2); overflow-x: auto; flex-wrap: nowrap; }
  .ward-anchor-inner a { font-size: 12px; padding: 4px 8px; white-space: nowrap; }
}

/* === Comparison matrix === */
.matrix-scroll {
  max-width: 1240px;
  margin: 0 auto;
  overflow-x: auto;
  padding-bottom: var(--sp-3);
  -webkit-overflow-scrolling: touch;
}
.matrix-table {
  width: 100%;
  min-width: 900px;
  border-collapse: collapse;
  background: var(--white);
  font-family: var(--mincho);
  border: 1px solid var(--line);
}
.matrix-table thead th {
  background: var(--ink-deep);
  color: var(--paper);
  font-weight: 500;
  font-size: 12px;
  padding: 14px 10px;
  text-align: center;
  letter-spacing: 0.08em;
  border-right: 1px solid rgba(255, 255, 255, 0.1);
  vertical-align: middle;
}
.matrix-table thead th small {
  display: block;
  font-size: 10px;
  color: var(--gold-bright);
  font-weight: 400;
  margin-top: 4px;
  letter-spacing: 0.05em;
}
.matrix-table tbody td {
  padding: 14px 10px;
  border-bottom: 1px solid var(--line-soft);
  border-right: 1px solid var(--line-soft);
  font-size: 13px;
  color: var(--text);
  text-align: center;
  vertical-align: middle;
  line-height: 1.7;
}
.matrix-table tbody td small {
  display: block;
  font-size: 10.5px;
  color: var(--text-soft);
  margin-top: 2px;
}
.matrix-table tbody tr:hover {
  background: rgba(226, 199, 154, 0.06);
}
.matrix-table .matrix-ward {
  background: var(--cream);
  font-family: var(--mincho-display);
  text-align: left;
  padding-left: var(--sp-4);
  position: sticky;
  left: 0;
  z-index: 1;
}
.matrix-table .matrix-ward strong {
  display: block;
  font-size: 15px;
  color: var(--ink-deep);
  font-weight: 600;
}
.matrix-table .matrix-ward small {
  display: block;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 10px;
  color: var(--gold-deep);
  letter-spacing: 0.2em;
}
.matrix-table .matrix-row-hot {
  background: linear-gradient(to right, rgba(226, 199, 154, 0.08), transparent 30%);
}

.matrix-table .up { color: var(--gold-deep); font-weight: 600; font-size: 11.5px; }
.matrix-table .up-hi { color: #b94d3d; font-weight: 700; font-size: 12px; }

.matrix-table .tag {
  display: inline-block;
  padding: 2px 8px;
  margin: 2px;
  font-size: 10.5px;
  border-radius: 2px;
  font-weight: 500;
  letter-spacing: 0.04em;
}
.matrix-table .tag-cap   { background: var(--ink-deep); color: var(--gold-bright); }
.matrix-table .tag-leg   { background: var(--gold);     color: var(--paper); }
.matrix-table .tag-fam   { background: #4a6b8a;         color: var(--paper); }
.matrix-table .tag-stab  { background: #6e8a4a;         color: var(--paper); }
.matrix-table .tag-yield { background: #b94d3d;         color: var(--paper); }
.matrix-table .tag-stud  { background: #8a4a6b;         color: var(--paper); }
.matrix-table .tag-new   { background: var(--gold-bright); color: var(--ink-deep); }

.matrix-note {
  max-width: 1240px;
  margin: var(--sp-4) auto 0;
  font-family: var(--mincho);
  font-size: 11.5px;
  color: var(--text-soft);
  line-height: 1.8;
  letter-spacing: 0.04em;
}

/* === Purpose grid === */
.purpose-grid {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
}
.purpose-card {
  background: var(--white);
  border: 1px solid var(--line-soft);
  padding: var(--sp-6);
  position: relative;
  transition: var(--t);
}
.purpose-card:hover {
  transform: translateY(-4px);
  border-color: var(--gold);
  box-shadow: 0 24px 50px rgba(10, 23, 41, 0.1);
}
.purpose-icon {
  font-size: 32px;
  margin-bottom: var(--sp-3);
  line-height: 1;
}
.purpose-tag {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold-deep);
  letter-spacing: 0.3em;
  margin-bottom: var(--sp-2);
}
.purpose-h {
  font-family: var(--mincho-display);
  font-size: 19px;
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  margin: 0 0 var(--sp-3);
}
.purpose-p {
  font-family: var(--mincho);
  font-size: 13.5px;
  line-height: 1.85;
  color: var(--text);
  margin: 0 0 var(--sp-4);
  letter-spacing: 0.04em;
}
.purpose-wards {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: var(--sp-3);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--line-soft);
}
.purpose-wards a {
  text-decoration: none;
  display: inline-block;
  padding: 5px 12px;
  background: var(--cream);
  border: 1px solid var(--gold-light);
  color: var(--ink-deep);
  font-family: var(--mincho);
  font-size: 12px;
  letter-spacing: 0.04em;
  transition: var(--t);
}
.purpose-wards a:hover {
  background: var(--gold);
  color: var(--paper);
  border-color: var(--gold);
}
.purpose-detail {
  font-family: var(--mincho);
  font-size: 11.5px;
  color: var(--text-soft);
  line-height: 1.75;
  letter-spacing: 0.03em;
}
@media (max-width: 1024px) {
  .purpose-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .purpose-grid { grid-template-columns: 1fr; }
}

/* === Rank chart (公示地価ランキング) === */
.rank-chart {
  max-width: 980px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.rank-row {
  display: grid;
  grid-template-columns: 32px 90px 1fr 180px;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: var(--white);
  border: 1px solid var(--line-soft);
  border-left: 4px solid var(--gold);
  transition: var(--t);
}
.rank-row:hover {
  transform: translateX(4px);
  box-shadow: 0 10px 24px rgba(10, 23, 41, 0.08);
}
.rank-pos {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 22px;
  color: var(--gold-deep);
  font-weight: 500;
  text-align: center;
}
.rank-name {
  font-family: var(--mincho-display);
  font-size: 16px;
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
}
.rank-name a {
  color: var(--ink-deep);
  text-decoration: none;
  border-bottom: 1px dashed transparent;
  transition: var(--t);
}
.rank-name a:hover {
  border-bottom-color: var(--gold);
  color: var(--gold-deep);
}
.rank-bar {
  height: 12px;
  background: var(--cream);
  border-radius: 6px;
  overflow: hidden;
  position: relative;
}
.rank-bar-fill {
  display: block;
  height: 100%;
  width: var(--bar, 50%);
  background: linear-gradient(to right, var(--gold), var(--gold-bright));
  border-radius: 6px;
  transition: width 1s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.rank-value {
  font-family: var(--mincho);
  font-size: 13.5px;
  color: var(--text);
  text-align: right;
  letter-spacing: 0.04em;
}
.rank-value strong {
  font-family: var(--serif-en);
  font-size: 18px;
  font-style: italic;
  color: var(--ink-deep);
  font-weight: 500;
  margin-right: 4px;
}
.rank-value .up { color: var(--gold-deep); font-weight: 600; font-style: normal; margin-left: 6px; font-size: 12px; }
.rank-value .up-hi { color: #b94d3d; font-weight: 700; font-style: normal; margin-left: 6px; font-size: 12px; }
@media (max-width: 768px) {
  .rank-row {
    grid-template-columns: 28px 70px 1fr;
    grid-template-rows: auto auto;
    gap: 6px;
  }
  .rank-bar { grid-column: 1 / -1; }
  .rank-value { grid-column: 1 / -1; text-align: left; font-size: 12.5px; }
}

/* ============================================
   Footer Layout (v2.2.1)
   ============================================ */
.site-footer { background: var(--ink-deep); color: var(--paper); padding: 0; position: relative; overflow: hidden; }
.footer-decor-top { height: 1px; background: linear-gradient(to right, transparent, var(--gold) 20%, var(--gold) 80%, transparent); margin-bottom: var(--sp-9); }

.footer-inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 var(--sp-7) var(--sp-8);
  display: grid;
  grid-template-columns: minmax(280px, 1.1fr) 2.4fr;
  gap: var(--sp-9);
  align-items: start;
}

.footer-brand-col { display: flex; flex-direction: column; gap: var(--sp-5); }
.footer-logo-img { max-width: 220px; height: auto; filter: brightness(0) invert(1); opacity: 0.95; }
.footer-tagline { font-family: var(--serif-en); font-style: italic; font-size: 14px; color: var(--gold-bright); line-height: 1.65; letter-spacing: 0.12em; margin: 0; }
.footer-addr { font-family: var(--mincho); font-size: 12.5px; line-height: 1.95; color: rgba(250, 247, 240, 0.78); letter-spacing: 0.04em; }
.footer-phone-link { display: inline-flex; flex-direction: column; gap: 4px; padding: var(--sp-4) var(--sp-5); background: rgba(226, 199, 154, 0.06); border: 1px solid rgba(226, 199, 154, 0.28); color: var(--paper); text-decoration: none; transition: var(--t); align-self: flex-start; }
.footer-phone-link:hover { background: rgba(226, 199, 154, 0.14); border-color: var(--gold); }
.footer-phone-label { font-family: var(--serif-en); font-style: italic; font-size: 10.5px; color: var(--gold-bright); letter-spacing: 0.35em; font-weight: 500; }
.footer-phone-num { font-family: var(--serif-en); font-size: 22px; font-weight: 500; letter-spacing: 0.06em; color: var(--paper); }
.footer-phone-hours { font-family: var(--mincho); font-size: 11.5px; color: rgba(250, 247, 240, 0.65); letter-spacing: 0.06em; }

.footer-nav-cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-6) var(--sp-5); align-items: start; }
.footer-col { display: flex; flex-direction: column; gap: 2px; }
.footer-col h4 { font-family: var(--serif-en); font-style: italic; font-size: 12px; color: var(--gold-bright); letter-spacing: 0.35em; font-weight: 500; margin: 0 0 var(--sp-3); padding-bottom: var(--sp-2); border-bottom: 1px solid rgba(226, 199, 154, 0.22); text-transform: uppercase; }
.footer-col a { font-family: var(--mincho); font-size: 13px; color: rgba(250, 247, 240, 0.82); text-decoration: none; letter-spacing: 0.05em; padding: 6px 0; border-bottom: 1px dashed transparent; transition: var(--t); width: fit-content; }
.footer-col a:hover { color: var(--gold-bright); border-bottom-color: var(--gold); }

.footer-mid { border-top: 1px solid rgba(226, 199, 154, 0.18); border-bottom: 1px solid rgba(226, 199, 154, 0.18); background: rgba(0, 0, 0, 0.16); }
.footer-mid-inner { max-width: 1240px; margin: 0 auto; padding: var(--sp-5) var(--sp-7); }
.footer-credentials { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); }
.footer-cred-item { display: flex; flex-direction: column; gap: 4px; }
.footer-cred-en { font-family: var(--serif-en); font-style: italic; font-size: 10.5px; color: var(--gold-bright); letter-spacing: 0.32em; font-weight: 500; text-transform: uppercase; }
.footer-cred-jp { font-family: var(--mincho); font-size: 12px; color: rgba(250, 247, 240, 0.82); line-height: 1.7; letter-spacing: 0.05em; }

.footer-bottom { background: rgba(0, 0, 0, 0.28); }
.footer-bottom-inner { max-width: 1240px; margin: 0 auto; padding: var(--sp-4) var(--sp-7); display: flex; justify-content: space-between; align-items: center; gap: var(--sp-5); flex-wrap: wrap; }
.footer-copyright { font-family: var(--mincho); font-size: 11.5px; color: rgba(250, 247, 240, 0.6); letter-spacing: 0.06em; }
.footer-tagline-en { font-family: var(--serif-en); font-style: italic; font-size: 11.5px; color: var(--gold-light); letter-spacing: 0.22em; }

@media (max-width: 1024px) {
  .footer-inner { grid-template-columns: 1fr; gap: var(--sp-7); }
  .footer-nav-cols { grid-template-columns: repeat(2, 1fr); }
  .footer-credentials { grid-template-columns: 1fr; gap: var(--sp-4); }
}
@media (max-width: 640px) {
  .footer-inner { padding: 0 var(--sp-5) var(--sp-6); }
  .footer-nav-cols { grid-template-columns: 1fr; gap: var(--sp-4); }
  .footer-mid-inner, .footer-bottom-inner { padding-left: var(--sp-5); padding-right: var(--sp-5); }
  .footer-bottom-inner { flex-direction: column; align-items: flex-start; text-align: left; }
  .footer-logo-img { max-width: 180px; }
  .footer-phone-num { font-size: 20px; }
}

/* ============================================
   Sell Hub Section (v2.3.0+) — 20億仲介の主導線
   ============================================ */
.sell-hub {
  background: linear-gradient(180deg, var(--paper) 0%, var(--cream) 100%);
  padding: var(--sp-10) var(--sp-7);
  position: relative;
}
.sell-hub-inner { max-width: 1240px; margin: 0 auto; }

.sell-hub-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr;
  gap: var(--sp-5);
  margin: var(--sp-7) auto 0;
}
.sell-card {
  background: var(--white);
  border: 1px solid var(--line-soft);
  padding: var(--sp-6);
  text-decoration: none;
  color: inherit;
  transition: var(--t);
  display: flex;
  flex-direction: column;
  position: relative;
}
.sell-card:hover {
  transform: translateY(-6px);
  border-color: var(--gold);
  box-shadow: 0 30px 60px rgba(10, 23, 41, 0.12);
  color: inherit;
}
.sell-card-primary {
  background: linear-gradient(135deg, var(--ink-deep) 0%, var(--ink) 100%);
  color: var(--paper);
  border-color: var(--gold);
}
.sell-card-primary .sell-card-tag { color: var(--gold-bright); }
.sell-card-primary .sell-card-h { color: var(--paper); }
.sell-card-primary .sell-card-p { color: rgba(250, 247, 240, 0.85); }
.sell-card-primary .sell-card-tags span {
  background: rgba(226, 199, 154, 0.12);
  border-color: rgba(226, 199, 154, 0.4);
  color: var(--gold-bright);
}
.sell-card-primary .sell-card-link {
  color: var(--gold-bright);
  border-bottom-color: var(--gold-bright);
}

.sell-card-tag {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11.5px;
  color: var(--gold-deep);
  letter-spacing: 0.32em;
  margin-bottom: var(--sp-3);
  font-weight: 500;
}
.sell-card-h {
  font-family: var(--mincho-display);
  font-size: 22px;
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  line-height: 1.5;
  margin: 0 0 var(--sp-3);
}
.sell-card-p {
  font-family: var(--mincho);
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--text);
  letter-spacing: 0.04em;
  margin: 0 0 var(--sp-4);
  flex-grow: 1;
}
.sell-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--line-soft);
}
.sell-card-tags span {
  display: inline-block;
  padding: 3px 10px;
  font-family: var(--mincho);
  font-size: 11px;
  background: var(--cream);
  border: 1px solid var(--gold-light);
  color: var(--gold-deep);
  letter-spacing: 0.04em;
}
.sell-card-link {
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--gold-deep);
  border-bottom: 1px solid var(--gold-deep);
  padding-bottom: 2px;
  letter-spacing: 0.06em;
  width: fit-content;
}

.sell-hub-note {
  text-align: center;
  font-family: var(--mincho);
  font-size: 12px;
  color: var(--text-soft);
  line-height: 1.95;
  margin: var(--sp-6) auto 0;
  letter-spacing: 0.04em;
  max-width: 720px;
}

@media (max-width: 1024px) {
  .sell-hub-grid { grid-template-columns: 1fr; gap: var(--sp-4); }
}
@media (max-width: 640px) {
  .sell-hub { padding: var(--sp-8) var(--sp-5); }
  .sell-card { padding: var(--sp-5); }
  .sell-card-h { font-size: 19px; }
}

/* =================================================================
   ROA Request Page — Scene Tabs / Report Sample / Flow / FAQ
   (v=20260528D)
   ================================================================= */

/* --- 3 Scenes Section --- */
.roa-scene-section {
  background: var(--paper);
  padding: var(--sp-12) var(--sp-6);
  border-top: 1px solid var(--line-soft);
}
.roa-scene-inner { max-width: 1180px; margin: 0 auto; }
.roa-scene-meta {
  font-family: var(--serif-en);
  font-size: 12px;
  color: var(--gold-deep);
  letter-spacing: 0.22em;
  text-align: center;
  margin-bottom: var(--sp-4);
}
.roa-scene-h {
  font-family: var(--mincho-display);
  font-size: clamp(24px, 3.6vw, 34px);
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: 0.06em;
  color: var(--ink-deep);
  text-align: center;
  margin: 0 0 var(--sp-5);
}
.roa-scene-h em {
  font-style: normal;
  color: var(--brand-orange);
  border-bottom: 2px solid var(--gold-bright);
  padding-bottom: 2px;
}
.roa-scene-lead {
  font-family: var(--mincho);
  font-size: 15px;
  line-height: 2;
  color: var(--text-soft);
  text-align: center;
  max-width: 820px;
  margin: 0 auto var(--sp-9);
  letter-spacing: 0.05em;
}

.roa-scene-tabs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-3);
  max-width: 880px;
  margin: 0 auto var(--sp-7);
}
.roa-scene-tab {
  font-family: var(--mincho-display);
  font-size: 15px;
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: 0.08em;
  color: var(--text-soft);
  background: var(--white);
  border: 1px solid var(--line-soft);
  padding: var(--sp-5) var(--sp-4);
  cursor: pointer;
  transition: all 0.3s ease;
  text-align: center;
  border-radius: 2px;
}
.roa-scene-tab span {
  display: block;
  font-family: var(--serif-en);
  font-size: 11px;
  letter-spacing: 0.18em;
  margin-top: 6px;
  opacity: 0.75;
}
.roa-scene-tab:hover {
  color: var(--ink-deep);
  border-color: var(--gold-bright);
}
.roa-scene-tab.is-active {
  color: var(--paper);
  background: var(--ink-deep);
  border-color: var(--ink-deep);
  box-shadow: 0 12px 28px rgba(10,23,41,0.16);
}
.roa-scene-tab.is-active span { color: var(--gold-bright); opacity: 1; }

.roa-scene-panel { display: none; }
.roa-scene-panel.is-active { display: block; animation: roaScenefadein 0.45s ease; }
@keyframes roaScenefadein {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

.roa-scene-card {
  background: var(--white);
  border: 1px solid var(--line-soft);
  border-top: 3px solid var(--gold-bright);
  padding: var(--sp-9) var(--sp-8);
  max-width: 940px;
  margin: 0 auto;
  box-shadow: 0 18px 48px rgba(10,23,41,0.06);
}
.roa-scene-card-en {
  font-family: var(--serif-en);
  font-size: 12px;
  color: var(--gold-deep);
  letter-spacing: 0.22em;
  margin-bottom: var(--sp-3);
}
.roa-scene-card-h {
  font-family: var(--mincho-display);
  font-size: clamp(20px, 2.8vw, 26px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.05em;
  color: var(--ink-deep);
  margin: 0 0 var(--sp-5);
}
.roa-scene-card-h em {
  font-style: normal;
  color: var(--brand-orange);
}
.roa-scene-card-lead {
  font-family: var(--mincho);
  font-size: 14.5px;
  line-height: 2;
  color: var(--text-soft);
  letter-spacing: 0.05em;
  margin: 0 0 var(--sp-7);
}
.roa-scene-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-6);
  display: grid;
  gap: var(--sp-5);
}
.roa-scene-list li {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: var(--sp-5);
  align-items: start;
  padding: var(--sp-5);
  background: var(--paper);
  border-left: 2px solid var(--gold-bright);
}
.roa-scene-list-num {
  font-family: var(--serif-en);
  font-size: 22px;
  color: var(--gold-deep);
  letter-spacing: 0.08em;
  line-height: 1;
}
.roa-scene-list li > div {
  font-family: var(--mincho);
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--text);
  letter-spacing: 0.04em;
}
.roa-scene-list li strong {
  display: block;
  font-family: var(--mincho-display);
  font-size: 15px;
  font-weight: 500;
  color: var(--ink-deep);
  margin-bottom: 6px;
  letter-spacing: 0.06em;
}
.roa-scene-card-note {
  font-family: var(--mincho);
  font-size: 12.5px;
  line-height: 1.9;
  color: var(--text-soft);
  letter-spacing: 0.04em;
  padding: var(--sp-4) var(--sp-5);
  background: var(--paper-warm);
  border-left: 2px solid var(--gold-deep);
}

/* --- Report Sample --- */
.roa-report-section {
  background: var(--paper-warm);
  padding: var(--sp-12) var(--sp-6);
}
.roa-report-inner { max-width: 1180px; margin: 0 auto; }
.roa-report-meta {
  font-family: var(--serif-en);
  font-size: 12px;
  color: var(--gold-deep);
  letter-spacing: 0.22em;
  text-align: center;
  margin-bottom: var(--sp-4);
}
.roa-report-h {
  font-family: var(--mincho-display);
  font-size: clamp(24px, 3.6vw, 34px);
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: 0.06em;
  color: var(--ink-deep);
  text-align: center;
  margin: 0 0 var(--sp-5);
}
.roa-report-h em {
  font-style: normal;
  color: var(--brand-orange);
  border-bottom: 2px solid var(--gold-bright);
  padding-bottom: 2px;
}
.roa-report-lead {
  font-family: var(--mincho);
  font-size: 15px;
  line-height: 2;
  color: var(--text-soft);
  text-align: center;
  max-width: 820px;
  margin: 0 auto var(--sp-9);
  letter-spacing: 0.05em;
}
.roa-report-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
}
.roa-report-card {
  background: var(--white);
  border: 1px solid var(--line-soft);
  padding: var(--sp-6) var(--sp-5);
  position: relative;
  box-shadow: 0 10px 28px rgba(10,23,41,0.05);
  display: flex;
  flex-direction: column;
}
.roa-report-card.is-final {
  background: var(--ink-deep);
  color: var(--paper);
  border-color: var(--ink-deep);
}
.roa-report-card-num {
  font-family: var(--serif-en);
  font-size: 12px;
  color: var(--gold-deep);
  letter-spacing: 0.2em;
  margin-bottom: var(--sp-2);
}
.roa-report-card.is-final .roa-report-card-num { color: var(--gold-bright); }
.roa-report-card-cat {
  font-family: var(--serif-en);
  font-size: 11px;
  color: var(--text-soft);
  letter-spacing: 0.2em;
  margin-bottom: var(--sp-3);
}
.roa-report-card.is-final .roa-report-card-cat { color: var(--paper-warm); opacity: 0.7; }
.roa-report-card-h {
  font-family: var(--mincho-display);
  font-size: 18px;
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: 0.06em;
  color: var(--ink-deep);
  margin: 0 0 var(--sp-4);
}
.roa-report-card.is-final .roa-report-card-h { color: var(--paper); }
.roa-report-card p {
  font-family: var(--mincho);
  font-size: 13px;
  line-height: 1.95;
  color: var(--text);
  letter-spacing: 0.04em;
  margin: 0;
}
.roa-report-card.is-final p { color: var(--paper-warm); opacity: 0.92; }

.roa-report-card-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-2);
  margin-top: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px dashed var(--line-soft);
}
.roa-report-stat {
  text-align: center;
  padding: var(--sp-2);
  background: var(--paper);
}
.roa-report-stat-l {
  display: block;
  font-family: var(--serif-en);
  font-size: 10px;
  color: var(--gold-deep);
  letter-spacing: 0.16em;
  margin-bottom: 4px;
}
.roa-report-stat-v {
  display: block;
  font-family: var(--serif-en);
  font-size: 22px;
  font-weight: 500;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
}
.roa-report-stat-v em {
  font-style: normal;
  font-size: 13px;
  color: var(--text-soft);
  margin-left: 2px;
}
.roa-report-card-graph {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  align-items: end;
  gap: 4px;
  height: 64px;
  margin-top: var(--sp-4);
  padding: 0 4px;
}
.roa-report-graph-bar {
  background: linear-gradient(to top, var(--gold-deep), var(--gold-bright));
  opacity: 0.55;
  border-radius: 1px 1px 0 0;
  min-height: 4px;
}
.roa-report-graph-bar.is-accent { opacity: 1; background: linear-gradient(to top, var(--brand-orange), var(--gold-bright)); }
.roa-report-card-graph-l {
  font-family: var(--serif-en);
  font-size: 10px;
  color: var(--text-soft);
  letter-spacing: 0.16em;
  text-align: center;
  margin-top: 6px;
}

.roa-report-card-pattern {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-2);
  margin-top: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px dashed var(--line-soft);
}
.roa-report-pattern-item {
  padding: var(--sp-2);
  background: var(--paper);
  text-align: center;
  border-left: 2px solid var(--gold-bright);
}
.roa-report-pattern-item.is-warn { border-left-color: var(--accent-vermillion, #b94e3b); }
.roa-report-pattern-l {
  font-family: var(--serif-en);
  font-size: 10px;
  color: var(--gold-deep);
  letter-spacing: 0.16em;
  margin-bottom: 4px;
}
.roa-report-pattern-v {
  font-family: var(--mincho);
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
}

.roa-report-disclaimer {
  font-family: var(--mincho);
  font-size: 12px;
  line-height: 1.85;
  color: var(--text-soft);
  text-align: center;
  margin-top: var(--sp-7);
  letter-spacing: 0.04em;
  max-width: 820px;
  margin-left: auto;
  margin-right: auto;
}

/* --- Flow Section --- */
.roa-flow-section {
  background: var(--paper);
  padding: var(--sp-12) var(--sp-6);
}
.roa-flow-inner { max-width: 1180px; margin: 0 auto; }
.roa-flow-meta {
  font-family: var(--serif-en);
  font-size: 12px;
  color: var(--gold-deep);
  letter-spacing: 0.22em;
  text-align: center;
  margin-bottom: var(--sp-4);
}
.roa-flow-h {
  font-family: var(--mincho-display);
  font-size: clamp(24px, 3.6vw, 34px);
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: 0.06em;
  color: var(--ink-deep);
  text-align: center;
  margin: 0 0 var(--sp-5);
}
.roa-flow-h em {
  font-style: normal;
  color: var(--brand-orange);
  border-bottom: 2px solid var(--gold-bright);
  padding-bottom: 2px;
}
.roa-flow-lead {
  font-family: var(--mincho);
  font-size: 15px;
  line-height: 2;
  color: var(--text-soft);
  text-align: center;
  max-width: 820px;
  margin: 0 auto var(--sp-9);
  letter-spacing: 0.05em;
}
.roa-flow-steps {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-9);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-4);
  position: relative;
}
.roa-flow-steps::before {
  content: "";
  position: absolute;
  top: 78px;
  left: 8%;
  right: 8%;
  height: 1px;
  background: repeating-linear-gradient(to right, var(--gold-bright) 0, var(--gold-bright) 6px, transparent 6px, transparent 12px);
  z-index: 0;
}
.roa-flow-step {
  background: var(--white);
  border: 1px solid var(--line-soft);
  padding: var(--sp-6) var(--sp-5);
  position: relative;
  z-index: 1;
  text-align: left;
  box-shadow: 0 10px 26px rgba(10,23,41,0.05);
}
.roa-flow-step-num {
  font-family: var(--serif-en);
  font-size: 32px;
  font-weight: 500;
  color: var(--gold-deep);
  letter-spacing: 0.04em;
  line-height: 1;
  margin-bottom: var(--sp-2);
}
.roa-flow-step-day {
  font-family: var(--serif-en);
  font-size: 11px;
  color: var(--gold-bright);
  letter-spacing: 0.2em;
  background: var(--ink-deep);
  color: var(--gold-bright);
  display: inline-block;
  padding: 3px 10px;
  margin-bottom: var(--sp-3);
}
.roa-flow-step-h {
  font-family: var(--mincho-display);
  font-size: 17px;
  font-weight: 500;
  color: var(--ink-deep);
  letter-spacing: 0.06em;
  margin: 0 0 var(--sp-3);
}
.roa-flow-step p {
  font-family: var(--mincho);
  font-size: 12.5px;
  line-height: 1.95;
  color: var(--text);
  letter-spacing: 0.04em;
  margin: 0;
}

.roa-flow-promise {
  background: var(--ink-deep);
  color: var(--paper);
  padding: var(--sp-7) var(--sp-7);
  text-align: center;
  max-width: 960px;
  margin: 0 auto;
}
.roa-flow-promise-l {
  font-family: var(--serif-en);
  font-size: 12px;
  color: var(--gold-bright);
  letter-spacing: 0.22em;
  margin-bottom: var(--sp-5);
}
.roa-flow-promise-items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
}
.roa-flow-promise-item {
  font-family: var(--mincho);
  font-size: 13px;
  line-height: 1.95;
  color: var(--paper-warm);
  letter-spacing: 0.05em;
  padding: 0 var(--sp-3);
}
.roa-flow-promise-item strong {
  display: block;
  font-family: var(--mincho-display);
  font-size: 15px;
  font-weight: 500;
  color: var(--gold-bright);
  margin-bottom: var(--sp-2);
  letter-spacing: 0.08em;
}

/* --- FAQ Section --- */
.roa-faq-section {
  background: var(--paper-warm);
  padding: var(--sp-12) var(--sp-6);
}
.roa-faq-inner { max-width: 920px; margin: 0 auto; }
.roa-faq-meta {
  font-family: var(--serif-en);
  font-size: 12px;
  color: var(--gold-deep);
  letter-spacing: 0.22em;
  text-align: center;
  margin-bottom: var(--sp-4);
}
.roa-faq-h {
  font-family: var(--mincho-display);
  font-size: clamp(24px, 3.6vw, 34px);
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: 0.06em;
  color: var(--ink-deep);
  text-align: center;
  margin: 0 0 var(--sp-9);
}
.roa-faq-h em {
  font-style: normal;
  color: var(--brand-orange);
  border-bottom: 2px solid var(--gold-bright);
  padding-bottom: 2px;
}
.roa-faq-list { display: grid; gap: var(--sp-3); }
.roa-faq-list .faq-item-body {
  padding: 0 var(--sp-6) var(--sp-5);
  font-family: var(--mincho);
  font-size: 13.5px;
  line-height: 2;
  color: var(--text);
  letter-spacing: 0.04em;
}
.roa-faq-list .faq-item-body p { margin: 0 0 var(--sp-3); }
.roa-faq-list .faq-item-body p:last-child { margin-bottom: 0; }

/* Responsive */
@media (max-width: 1024px) {
  .roa-report-grid { grid-template-columns: repeat(2, 1fr); }
  .roa-flow-steps { grid-template-columns: repeat(2, 1fr); }
  .roa-flow-steps::before { display: none; }
  .roa-flow-promise-items { grid-template-columns: 1fr; gap: var(--sp-4); }
}
@media (max-width: 720px) {
  .roa-scene-section, .roa-report-section, .roa-flow-section, .roa-faq-section { padding: var(--sp-9) var(--sp-4); }
  .roa-scene-tabs { grid-template-columns: 1fr; }
  .roa-scene-card { padding: var(--sp-6) var(--sp-5); }
  .roa-scene-list li { grid-template-columns: 44px 1fr; gap: var(--sp-3); padding: var(--sp-4); }
  .roa-scene-list-num { font-size: 18px; }
  .roa-report-grid { grid-template-columns: 1fr; }
  .roa-flow-steps { grid-template-columns: 1fr; }
  .roa-flow-promise { padding: var(--sp-6) var(--sp-5); }
  .roa-report-card-stats { grid-template-columns: repeat(3, 1fr); gap: 4px; }
  .roa-report-stat-v { font-size: 18px; }
}

/* ============================================
   Voice — Anonymous Case Cards (20260528D)
   ============================================ */
.voice-anon-intro {
  max-width: 960px;
  margin: 0 auto var(--sp-7);
  text-align: center;
  padding: 0 var(--sp-5);
}
.voice-anon-intro-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 14px;
  color: var(--gold);
  letter-spacing: 0.18em;
  margin-bottom: var(--sp-3);
}
.voice-anon-intro h2 {
  font-family: var(--mincho-display);
  font-size: 30px;
  font-weight: 500;
  color: var(--ink-deep);
  letter-spacing: 0.06em;
  line-height: 1.5;
  margin-bottom: var(--sp-4);
}
.voice-anon-intro h2 em {
  color: var(--brand-orange, var(--gold));
  font-style: normal;
  border-bottom: 1px dashed var(--gold-light);
  padding-bottom: 2px;
}
.voice-anon-intro p {
  font-family: var(--mincho);
  font-size: 15px;
  line-height: 2;
  color: var(--ink-mid);
  letter-spacing: 0.04em;
}
.voice-anon-disclaimer {
  display: inline-block;
  margin-top: var(--sp-4);
  padding: 10px 18px;
  background: var(--paper-warm);
  border-left: 3px solid var(--gold);
  font-family: var(--mincho);
  font-size: 12.5px;
  color: var(--ink-mid);
  letter-spacing: 0.05em;
  line-height: 1.7;
  text-align: left;
}

/* ── Tab filter ── */
.voice-tabs {
  max-width: 1080px;
  margin: 0 auto var(--sp-7);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-3);
  padding: 0 var(--sp-5);
}
.voice-tab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 22px;
  background: var(--white);
  border: 1px solid var(--line);
  color: var(--ink-mid);
  font-family: var(--mincho);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.08em;
  cursor: pointer;
  transition: all var(--t-fast);
  border-radius: 2px;
}
.voice-tab:hover {
  border-color: var(--gold);
  color: var(--ink-deep);
  transform: translateY(-1px);
}
.voice-tab .voice-tab-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold);
  letter-spacing: 0.12em;
}
.voice-tab.is-active {
  background: var(--ink-deep);
  border-color: var(--ink-deep);
  color: var(--paper);
}
.voice-tab.is-active .voice-tab-en {
  color: var(--gold-bright);
}
.voice-tab-count {
  display: inline-block;
  min-width: 22px;
  padding: 2px 6px;
  background: var(--paper-warm);
  color: var(--ink-mid);
  font-family: var(--serif-en);
  font-size: 11px;
  border-radius: 10px;
  text-align: center;
}
.voice-tab.is-active .voice-tab-count {
  background: var(--gold);
  color: var(--ink-deep);
}

/* ── Anonymous case grid ── */
.voice-anon-grid {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
  padding: 0 var(--sp-5);
}
.voice-card-anon {
  background: var(--white);
  border: 1px solid var(--line-soft);
  padding: var(--sp-6);
  position: relative;
  transition: all var(--t);
  display: flex;
  flex-direction: column;
}
.voice-card-anon:hover {
  border-color: var(--gold-light);
  box-shadow: var(--shadow);
  transform: translateY(-3px);
}
.voice-card-anon.is-hidden {
  display: none;
}
.voice-card-anon-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--line-soft);
}
.voice-card-anon-cat {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: var(--ink-deep);
  color: var(--paper);
  font-family: var(--serif-en);
  font-size: 11px;
  font-style: italic;
  letter-spacing: 0.16em;
  border-radius: 2px;
}
.voice-card-anon-cat.cat-sell { background: #1d3865; }
.voice-card-anon-cat.cat-inh { background: #826335; }
.voice-card-anon-cat.cat-bldg { background: #0a1729; }
.voice-card-anon-cat.cat-corp { background: #3a5685; }
.voice-card-anon-cat.cat-swap { background: #b08855; }
.voice-card-anon-no {
  font-family: var(--serif-en);
  font-size: 13px;
  font-style: italic;
  color: var(--gold);
  letter-spacing: 0.1em;
}
.voice-card-anon-profile {
  font-family: var(--mincho-display);
  font-size: 16px;
  font-weight: 500;
  color: var(--ink-deep);
  letter-spacing: 0.05em;
  line-height: 1.55;
  margin-bottom: var(--sp-2);
}
.voice-card-anon-asset {
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--ink-mid);
  letter-spacing: 0.04em;
  line-height: 1.7;
  padding: 8px 12px;
  background: var(--paper);
  border-left: 2px solid var(--gold);
  margin-bottom: var(--sp-4);
}
.voice-card-anon-row {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px dashed var(--line-soft);
}
.voice-card-anon-row:last-child { border-bottom: none; }
.voice-card-anon-label {
  font-family: var(--serif-en);
  font-size: 10.5px;
  font-style: italic;
  color: var(--gold);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding-top: 2px;
}
.voice-card-anon-val {
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--ink-deep);
  line-height: 1.85;
  letter-spacing: 0.03em;
}
.voice-card-anon-val strong {
  color: var(--ink-deep);
  font-weight: 700;
  background: linear-gradient(transparent 65%, rgba(204,170,120,0.35) 65%);
  padding: 0 2px;
}
.voice-card-anon-result {
  margin-top: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  background: linear-gradient(135deg, rgba(176,136,85,0.08), rgba(204,170,120,0.04));
  border: 1px solid var(--gold-light);
}
.voice-card-anon-result-label {
  font-family: var(--serif-en);
  font-size: 10.5px;
  font-style: italic;
  color: var(--gold-deep);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.voice-card-anon-result-val {
  font-family: var(--mincho-display);
  font-size: 14.5px;
  color: var(--ink-deep);
  font-weight: 500;
  line-height: 1.7;
  letter-spacing: 0.04em;
}
.voice-card-anon-foot {
  margin-top: var(--sp-4);
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.voice-card-anon-chip {
  display: inline-block;
  padding: 4px 10px;
  background: var(--paper-warm);
  color: var(--ink-mid);
  font-family: var(--mincho);
  font-size: 11.5px;
  letter-spacing: 0.06em;
  border-radius: 12px;
}

/* ── Empty state ── */
.voice-empty {
  grid-column: 1 / -1;
  padding: var(--sp-8) var(--sp-5);
  text-align: center;
  font-family: var(--mincho);
  color: var(--text-soft);
  font-size: 14px;
  display: none;
}
.voice-empty.is-active { display: block; }

/* ── CTA below cards ── */
.voice-anon-cta {
  margin-top: var(--sp-9);
  padding: var(--sp-8) var(--sp-7);
  background: var(--ink-deep);
  color: var(--paper);
  text-align: center;
}
.voice-anon-cta-en {
  font-family: var(--serif-en);
  font-style: italic;
  color: var(--gold-bright);
  letter-spacing: 0.18em;
  font-size: 13px;
  margin-bottom: var(--sp-3);
}
.voice-anon-cta-h {
  font-family: var(--mincho-display);
  font-size: 26px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.55;
  margin-bottom: var(--sp-6);
}
.voice-anon-cta-h em {
  color: var(--gold-bright);
  font-style: normal;
}
.voice-anon-cta-grid {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
}
.voice-anon-cta-card {
  display: block;
  padding: var(--sp-6) var(--sp-5);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(204,170,120,0.35);
  color: var(--paper);
  text-decoration: none;
  text-align: left;
  transition: all var(--t);
}
.voice-anon-cta-card:hover {
  background: rgba(204,170,120,0.08);
  border-color: var(--gold-bright);
  transform: translateY(-3px);
  color: var(--paper);
}
.voice-anon-cta-card-tag {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold-bright);
  letter-spacing: 0.16em;
  margin-bottom: var(--sp-3);
}
.voice-anon-cta-card-h {
  font-family: var(--mincho-display);
  font-size: 17px;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.55;
  margin-bottom: var(--sp-3);
}
.voice-anon-cta-card-p {
  font-family: var(--mincho);
  font-size: 13px;
  line-height: 1.85;
  color: rgba(250,247,240,0.82);
  margin-bottom: var(--sp-4);
}
.voice-anon-cta-card-arrow {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 13px;
  color: var(--gold-bright);
  letter-spacing: 0.1em;
}

@media (max-width: 960px) {
  .voice-anon-grid { grid-template-columns: repeat(2, 1fr); }
  .voice-anon-cta-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .voice-anon-intro h2 { font-size: 23px; }
  .voice-anon-grid { grid-template-columns: 1fr; gap: var(--sp-4); padding: 0 var(--sp-4); }
  .voice-card-anon { padding: var(--sp-5); }
  .voice-card-anon-row { grid-template-columns: 1fr; gap: 4px; }
  .voice-card-anon-label { font-size: 10px; }
  .voice-tab { padding: 10px 16px; font-size: 13px; }
  .voice-anon-cta { padding: var(--sp-7) var(--sp-5); }
  .voice-anon-cta-h { font-size: 21px; }
}

/* ============================================
   Valuation LP Enhancement (v2.5.0+)
   売却LP最終強化セクション群
   ============================================ */

/* === Hero CTA (大きく目立つ) === */
.sell-hero-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-top: var(--sp-6);
}
.sell-hero-cta .btn-xl {
  padding: 24px 48px;
  font-size: 16px;
  letter-spacing: 0.12em;
}
.sell-hero-promise {
  margin-top: var(--sp-4);
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--text-mid);
  letter-spacing: 0.05em;
}
.sell-hero-promise strong { color: var(--gold-deep); }

.sell-hero-scarcity {
  margin-top: var(--sp-4);
  padding: var(--sp-3) var(--sp-5);
  background: rgba(185, 77, 61, 0.06);
  border-left: 3px solid var(--gold);
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  max-width: 720px;
}
.sell-hero-scarcity strong { color: var(--gold-deep); font-weight: 600; }
.scarcity-dot {
  display: inline-block;
  color: var(--gold);
  font-size: 9px;
  vertical-align: middle;
  margin-right: 6px;
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 0.5; transform: scale(1); }
  50%      { opacity: 1;   transform: scale(1.2); }
}

/* === Why Aspartner (3つの強み) === */
.sell-why-grid {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
}
.sell-why-card {
  background: var(--white);
  border: 1px solid var(--line-soft);
  padding: var(--sp-6);
  position: relative;
}
.sell-why-card-highlight {
  background: linear-gradient(135deg, var(--ink-deep) 0%, var(--ink) 100%);
  color: var(--paper);
  border-color: var(--gold);
}
.sell-why-card-highlight .sell-why-num { color: var(--gold-bright); }
.sell-why-card-highlight .sell-why-h { color: var(--paper); }
.sell-why-card-highlight .sell-why-h em { color: var(--gold-bright); }
.sell-why-card-highlight .sell-why-p { color: rgba(250, 247, 240, 0.86); }
.sell-why-card-highlight .sell-why-list li { color: rgba(250, 247, 240, 0.86); }
.sell-why-card-highlight .sell-why-list li::before { color: var(--gold-bright); }
.sell-why-num {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 28px;
  color: var(--gold-deep);
  font-weight: 500;
  margin-bottom: var(--sp-3);
  line-height: 1;
}
.sell-why-tag {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.32em;
  margin-bottom: var(--sp-3);
}
.sell-why-h {
  font-family: var(--mincho-display);
  font-size: 20px;
  font-weight: 600;
  color: var(--ink-deep);
  margin: 0 0 var(--sp-3);
  line-height: 1.55;
  letter-spacing: 0.04em;
}
.sell-why-h em {
  font-style: normal;
  color: var(--gold-deep);
}
.sell-why-p {
  font-family: var(--mincho);
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--text);
  margin: 0 0 var(--sp-4);
}
.sell-why-list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid var(--line-soft);
  padding-top: var(--sp-4);
}
.sell-why-list li {
  font-family: var(--mincho);
  font-size: 12.5px;
  line-height: 1.9;
  color: var(--text-mid);
  padding-left: 18px;
  position: relative;
  letter-spacing: 0.04em;
}
.sell-why-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--gold);
  font-weight: 700;
}
@media (max-width: 1024px) {
  .sell-why-grid { grid-template-columns: 1fr; }
}

/* === Pricing Gap (Before/After) === */
.sell-diff-grid {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 40px 1fr;
  gap: var(--sp-4);
  align-items: stretch;
}
.sell-diff-card {
  padding: var(--sp-6);
  border: 1px solid var(--line-soft);
  background: var(--white);
  display: flex;
  flex-direction: column;
}
.sell-diff-card-bad {
  background: var(--paper-warm);
  opacity: 0.92;
}
.sell-diff-card-good {
  background: linear-gradient(135deg, var(--cream) 0%, rgba(226, 199, 154, 0.18) 100%);
  border-color: var(--gold);
  box-shadow: 0 24px 56px rgba(176, 136, 85, 0.16);
}
.sell-diff-card-tag {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--text-soft);
  letter-spacing: 0.3em;
  margin-bottom: var(--sp-3);
}
.sell-diff-card-good .sell-diff-card-tag { color: var(--gold-deep); }
.sell-diff-card-h {
  font-family: var(--mincho-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--ink-deep);
  margin: 0 0 var(--sp-4);
  letter-spacing: 0.04em;
}
.sell-diff-card-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-5);
  flex-grow: 1;
}
.sell-diff-card-list li {
  font-family: var(--mincho);
  font-size: 13.5px;
  line-height: 2.0;
  color: var(--text);
  letter-spacing: 0.04em;
}
.sell-diff-result {
  padding: var(--sp-4);
  background: var(--white);
  border-top: 2px solid var(--gold-light);
  font-family: var(--mincho);
  font-size: 13px;
  color: var(--text-soft);
  text-align: center;
  margin-top: auto;
}
.sell-diff-result strong {
  display: block;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 28px;
  color: var(--ink-deep);
  margin-top: 4px;
  font-weight: 500;
}
.sell-diff-card-good .sell-diff-result strong { color: var(--gold-deep); }
.sell-diff-tag-best {
  display: inline-block;
  padding: 4px 12px;
  background: var(--gold);
  color: var(--paper);
  font-family: var(--mincho);
  font-size: 11.5px;
  letter-spacing: 0.1em;
  margin-bottom: 6px;
}
.sell-diff-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  color: var(--gold);
  font-family: var(--serif-en);
}
.sell-diff-note {
  max-width: 1100px;
  margin: var(--sp-5) auto 0;
  font-family: var(--mincho);
  font-size: 11.5px;
  color: var(--text-soft);
  line-height: 1.85;
  letter-spacing: 0.04em;
}
.sell-diff-note strong { color: var(--ink-deep); }
@media (max-width: 768px) {
  .sell-diff-grid { grid-template-columns: 1fr; }
  .sell-diff-arrow { transform: rotate(90deg); padding: var(--sp-2); }
}

/* === Action Ladder (3段階) === */
.sell-ladder-grid {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
}
.sell-ladder-card {
  background: var(--white);
  border: 1px solid var(--line-soft);
  padding: var(--sp-6);
  text-decoration: none;
  color: inherit;
  transition: var(--t);
  display: flex;
  flex-direction: column;
  position: relative;
}
.sell-ladder-card:hover {
  transform: translateY(-5px);
  border-color: var(--gold);
  box-shadow: 0 24px 56px rgba(10, 23, 41, 0.1);
  color: inherit;
}
.sell-ladder-card-primary {
  background: linear-gradient(135deg, var(--ink-deep) 0%, var(--ink) 100%);
  color: var(--paper);
  border-color: var(--gold);
}
.sell-ladder-card-primary .sell-ladder-h { color: var(--paper); }
.sell-ladder-card-primary .sell-ladder-p { color: rgba(250, 247, 240, 0.86); }
.sell-ladder-card-primary .sell-ladder-meta { color: rgba(250, 247, 240, 0.7); border-color: rgba(226, 199, 154, 0.3); }
.sell-ladder-card-primary .sell-ladder-meta strong { color: var(--gold-bright); }
.sell-ladder-card-primary .sell-ladder-link { color: var(--gold-bright); border-bottom-color: var(--gold-bright); }
.sell-ladder-step {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold-deep);
  letter-spacing: 0.32em;
  margin-bottom: 4px;
  font-weight: 500;
}
.sell-ladder-card-primary .sell-ladder-step { color: var(--gold-bright); }
.sell-ladder-tag {
  font-family: var(--mincho);
  font-size: 11px;
  color: var(--text-soft);
  letter-spacing: 0.2em;
  margin-bottom: var(--sp-3);
}
.sell-ladder-card-primary .sell-ladder-tag { color: rgba(226, 199, 154, 0.7); }
.sell-ladder-h {
  font-family: var(--mincho-display);
  font-size: 21px;
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  line-height: 1.45;
  margin: 0 0 var(--sp-3);
}
.sell-ladder-p {
  font-family: var(--mincho);
  font-size: 13px;
  line-height: 1.9;
  color: var(--text);
  margin: 0 0 var(--sp-4);
  flex-grow: 1;
  letter-spacing: 0.04em;
}
.sell-ladder-meta {
  font-family: var(--mincho);
  font-size: 11.5px;
  color: var(--text-soft);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--line-soft);
  margin-bottom: var(--sp-3);
  letter-spacing: 0.04em;
}
.sell-ladder-meta strong { color: var(--gold-deep); }
.sell-ladder-link {
  font-family: var(--mincho);
  font-size: 12.5px;
  color: var(--gold-deep);
  border-bottom: 1px solid var(--gold-deep);
  padding-bottom: 2px;
  letter-spacing: 0.06em;
  width: fit-content;
}
@media (max-width: 1024px) {
  .sell-ladder-grid { grid-template-columns: 1fr; }
}

/* === Buyer Network === */
.sell-buyer-grid {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
}
.sell-buyer-card {
  background: var(--white);
  border: 1px solid var(--line-soft);
  padding: var(--sp-5);
  transition: var(--t);
}
.sell-buyer-card:hover {
  border-color: var(--gold-light);
  background: var(--cream);
}
.sell-buyer-card-self {
  background: linear-gradient(135deg, var(--cream) 0%, rgba(226, 199, 154, 0.16) 100%);
  border-color: var(--gold);
}
.sell-buyer-icon {
  font-size: 28px;
  margin-bottom: var(--sp-2);
  line-height: 1;
}
/* Typography-based markers (no emoji) */
.sell-buyer-num {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--gold-deep);
  margin-bottom: var(--sp-2);
  line-height: 1;
}
.sell-buyer-tag {
  font-family: var(--serif-en);
  font-size: 11px;
  font-style: italic;
  letter-spacing: 0.16em;
  color: var(--text-soft);
  margin-bottom: var(--sp-3);
  text-transform: uppercase;
}
.sell-buyer-card-self .sell-buyer-num,
.sell-buyer-card-self .sell-buyer-tag { color: var(--gold-deep); }
.sell-commit-tag {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--text-soft);
  margin-bottom: var(--sp-3);
  text-transform: uppercase;
}
/* Rate pills (replaces ★ stars) */
.rate-pill {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 999px;
  font-family: var(--mincho);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.4;
  white-space: nowrap;
}
.rate-pill.rate-high {
  background: linear-gradient(135deg, #f8e7c4 0%, #e2c79a 100%);
  color: #6b4a1c;
  border: 1px solid #d6b06a;
}
.rate-pill.rate-mid {
  background: rgba(226, 199, 154, 0.18);
  color: var(--gold-deep, #8e6c2a);
  border: 1px solid rgba(214, 176, 106, 0.45);
}
.rate-pill.rate-low {
  background: rgba(0,0,0,0.03);
  color: var(--text-soft);
  border: 1px solid rgba(0,0,0,0.08);
}
.sell-buyer-h {
  font-family: var(--mincho-display);
  font-size: 16px;
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  margin: 0 0 var(--sp-3);
}
.sell-buyer-p {
  font-family: var(--mincho);
  font-size: 12.5px;
  line-height: 1.9;
  color: var(--text);
  margin: 0;
  letter-spacing: 0.04em;
}
.sell-buyer-p strong { color: var(--gold-deep); }
.sell-buyer-note {
  text-align: center;
  font-family: var(--mincho);
  font-size: 12.5px;
  color: var(--text-soft);
  line-height: 1.85;
  margin: var(--sp-5) auto 0;
  max-width: 800px;
  letter-spacing: 0.04em;
}
@media (max-width: 1024px) {
  .sell-buyer-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .sell-buyer-grid { grid-template-columns: 1fr; }
}

/* === Fear Resolver (不安解消5枚) === */
.sell-fear-grid {
  max-width: 1100px;
  margin: 0 auto var(--sp-7);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-4);
}
.sell-fear-card {
  background: var(--white);
  border: 1px solid var(--line-soft);
  border-left: 4px solid var(--gold);
  padding: var(--sp-5);
}
.sell-fear-q {
  font-family: var(--mincho-display);
  font-size: 15.5px;
  font-weight: 600;
  color: var(--ink-deep);
  margin-bottom: var(--sp-3);
  letter-spacing: 0.04em;
}
.sell-fear-q::before {
  content: "Q. ";
  color: var(--gold-deep);
  font-family: var(--serif-en);
  font-style: italic;
  margin-right: 4px;
}
.sell-fear-a {
  font-family: var(--mincho);
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--text);
  letter-spacing: 0.04em;
}
.sell-fear-a strong { color: var(--gold-deep); font-weight: 600; }
@media (max-width: 768px) {
  .sell-fear-grid { grid-template-columns: 1fr; }
}

/* === Commitment (4つのお約束) === */
.sell-commit-grid {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-4);
}
.sell-commit-card {
  background: var(--cream);
  border: 1px solid var(--gold-light);
  padding: var(--sp-5);
  text-align: center;
}
.sell-commit-num {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 28px;
  color: var(--gold-deep);
  margin-bottom: 4px;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1;
}
.sell-commit-h {
  font-family: var(--mincho-display);
  font-size: 16px;
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  margin: 0 0 var(--sp-3);
  line-height: 1.5;
}
.sell-commit-p {
  font-family: var(--mincho);
  font-size: 12.5px;
  line-height: 1.85;
  color: var(--text);
  margin: 0;
  letter-spacing: 0.04em;
}
@media (max-width: 1024px) {
  .sell-commit-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .sell-commit-grid { grid-template-columns: 1fr; }
}

/* ============================================
   Hero Tagline & Brand Sub (v2.5.1+)
   売却軸H1 + 装飾タグライン + 情緒ブランドサブ
   ============================================ */
.hero-tagline {
  font-family: var(--mincho-display);
  font-size: clamp(14px, 1.6vw, 18px);
  color: var(--gold-bright);
  letter-spacing: 0.16em;
  margin-bottom: var(--sp-4);
  font-weight: 400;
  text-shadow: 0 0 24px rgba(226, 199, 154, 0.4);
  opacity: 0.95;
}
.hero-tagline::before, .hero-tagline::after {
  /* Already includes em-dash inline */
}
.hero-brand-sub {
  margin-top: var(--sp-5);
  font-family: var(--mincho);
  font-size: clamp(13px, 1.2vw, 15px);
  color: rgba(250, 247, 240, 0.65);
  letter-spacing: 0.12em;
  font-style: italic;
  border-top: 1px solid rgba(226, 199, 154, 0.18);
  padding-top: var(--sp-4);
  max-width: 640px;
}
.hero-brand-sub-en {
  display: block;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11.5px;
  color: var(--gold-light);
  letter-spacing: 0.28em;
  margin-top: 6px;
  text-transform: none;
}
@media (max-width: 768px) {
  .hero-tagline { font-size: 12px; letter-spacing: 0.12em; }
  .hero-brand-sub { font-size: 11.5px; padding-top: var(--sp-3); }
}

/* ============================================
   Hero Main Catch (v2.5.2+)
   「不動産と、明るい未来を ✦ あなたと、共に」をブランドキャッチに
   ============================================ */
.hero-catch-main {
  font-family: var(--mincho-display);
  font-size: clamp(32px, 5.2vw, 64px);
  line-height: 1.45;
  color: var(--gold-bright);
  letter-spacing: 0.06em;
  font-weight: 500;
  margin: var(--sp-4) 0 var(--sp-5);
  text-shadow: 0 4px 30px rgba(10, 23, 41, 0.5), 0 0 60px rgba(226, 199, 154, 0.25);
  animation: hero-catch-fadein 1.2s ease-out forwards;
  opacity: 0;
}
@keyframes hero-catch-fadein {
  0%   { opacity: 0; transform: translateY(14px); }
  100% { opacity: 1; transform: translateY(0); }
}

.hero-catch-spark {
  display: inline-block;
  color: var(--gold);
  font-size: 0.78em;
  margin: 0 6px;
  vertical-align: middle;
  animation: spark-twinkle 2.2s ease-in-out infinite;
  text-shadow: 0 0 16px var(--gold-bright);
}
@keyframes spark-twinkle {
  0%, 100% { opacity: 0.6; transform: rotate(0deg) scale(1); }
  50%      { opacity: 1;   transform: rotate(180deg) scale(1.15); }
}

/* H1 を売却特化のサブ的扱いに (キャッチがメイン視覚) */
.hero-h1.hero-h1-sub {
  font-size: clamp(22px, 3vw, 38px) !important;
  line-height: 1.48 !important;
  color: var(--paper) !important;
  font-weight: 500 !important;
  margin-bottom: var(--sp-4) !important;
  letter-spacing: 0.04em !important;
}
.hero-h1.hero-h1-sub em {
  color: var(--gold-bright);
  font-style: normal;
  font-weight: 600;
}
.hero-h1.hero-h1-sub .accent {
  display: block;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 0.4em;
  color: var(--gold-light);
  letter-spacing: 0.28em;
  margin-top: var(--sp-4);
  font-weight: 400;
}

@media (max-width: 768px) {
  .hero-catch-main { font-size: clamp(26px, 8vw, 42px); margin: var(--sp-3) 0 var(--sp-4); }
  .hero-h1.hero-h1-sub { font-size: clamp(18px, 5vw, 24px) !important; }
}

/* hero-catch-line: 改行制御で「を。」「あなたと、共に。」がきれいに収まるよう */
.hero-catch-line {
  display: block;
  line-height: 1.42;
}
.hero-catch-nowrap {
  white-space: nowrap;
  display: inline-block;
}
/* デスクトップでは少しサイズ抑える(きれいに収まる範囲に) */
@media (min-width: 769px) {
  .hero-catch-main { font-size: clamp(34px, 4.4vw, 56px); }
}
@media (max-width: 768px) {
  .hero-catch-nowrap { white-space: normal; }
  .hero-catch-main { font-size: clamp(24px, 7vw, 38px); }
}

/* ============================================
   Hero Catch SVG Image (v2.5.3+)
   ============================================ */
.hero-catch-image-wrap {
  margin: var(--sp-4) 0 var(--sp-5);
  animation: hero-catch-fadein 1.3s ease-out forwards;
  opacity: 0;
}
.hero-catch-image {
  display: block;
  width: 100%;
  max-width: 720px;
  height: auto;
  filter: drop-shadow(0 6px 30px rgba(10, 23, 41, 0.5));
}
@media (max-width: 768px) {
  .hero-catch-image-wrap { margin: var(--sp-3) 0 var(--sp-4); }
  .hero-catch-image { max-width: 100%; }
}

/* ============================================
   Hero Left-Bottom Balance Fix (v2.5.4+)
   3CTA + メタ情報 + SCROLL の位置を整理
   ============================================ */

/* 3つのCTAを「主＋サブ2」のメリハリある構成に */
.hero-cta-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: var(--sp-3) !important;
  align-items: stretch !important;
  max-width: 600px;
  margin-top: var(--sp-5) !important;
}
.hero-cta-row .btn {
  flex: 0 0 auto;
  white-space: nowrap;
}
/* 主CTA(売却査定)は大きく */
.hero-cta-row .btn-primary {
  flex: 1 1 100%;
  padding: 20px 32px !important;
  font-size: 16px !important;
  letter-spacing: 0.12em !important;
  background: linear-gradient(135deg, #b08855 0%, #826335 100%) !important;
  border: 1px solid var(--gold-bright) !important;
  box-shadow: 0 12px 36px rgba(176, 136, 85, 0.45), 0 0 0 1px rgba(226, 199, 154, 0.3) inset !important;
}
.hero-cta-row .btn-primary:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 18px 48px rgba(176, 136, 85, 0.6), 0 0 0 1px rgba(226, 199, 154, 0.5) inset !important;
}
/* サブCTA(60分相談 / ROA分析)は同等サイズで横並び */
.hero-cta-row .btn-gold,
.hero-cta-row .btn-outline {
  flex: 1 1 calc(50% - var(--sp-2));
  padding: 14px 20px !important;
  font-size: 13px !important;
  letter-spacing: 0.1em !important;
}
.hero-cta-row .btn-outline {
  background: rgba(10, 23, 41, 0.45) !important;
  border: 1px solid rgba(226, 199, 154, 0.5) !important;
  color: var(--gold-bright) !important;
  backdrop-filter: blur(6px);
}
.hero-cta-row .btn-outline:hover {
  background: rgba(10, 23, 41, 0.7) !important;
  border-color: var(--gold-bright) !important;
}

/* メタ情報をボタン下に小さく上品に */
.hero-meta {
  margin-top: var(--sp-4) !important;
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  font-family: var(--mincho) !important;
  font-size: 11px !important;
  color: rgba(250, 247, 240, 0.55) !important;
  letter-spacing: 0.18em !important;
  max-width: 600px;
}
.hero-meta span {
  margin-right: 0 !important;
}
.hero-meta span::before {
  content: "✓ " !important;
  color: var(--gold-bright) !important;
  margin-right: 4px !important;
}

/* SCROLL をボタンと重ならない位置に(右下) */
.hero-scroll {
  left: auto !important;
  right: var(--sp-7) !important;
  transform: none !important;
  bottom: var(--sp-7) !important;
}

@media (max-width: 768px) {
  .hero-cta-row { max-width: 100%; }
  .hero-cta-row .btn-primary { flex: 1 1 100%; }
  .hero-cta-row .btn-gold, .hero-cta-row .btn-outline { flex: 1 1 100%; }
  .hero-meta { font-size: 10.5px !important; gap: var(--sp-2); }
  .hero-scroll { right: 50% !important; transform: translateX(50%) !important; bottom: var(--sp-4) !important; }
}

/* ============================================
   Hero Compaction Fix (v2.5.5+)
   ヒーロー全体をビューポートに収め、左下のCTAを綺麗に
   ============================================ */

/* ヒーロー高さを最適化 */
.hero {
  min-height: 96vh !important;
  padding-top: var(--sp-7) !important;
  padding-bottom: var(--sp-7) !important;
}

/* SVGキャッチをコンパクトに */
.hero-catch-image {
  max-width: 560px !important;
}
.hero-catch-image-wrap {
  margin: var(--sp-3) 0 var(--sp-4) !important;
}

/* H1売却特化テキストを少しコンパクトに */
.hero-h1.hero-h1-sub {
  font-size: clamp(20px, 2.6vw, 32px) !important;
  margin-bottom: var(--sp-3) !important;
}
.hero-h1.hero-h1-sub .accent {
  font-size: 0.4em !important;
  margin-top: var(--sp-3) !important;
}

/* サブテキストもコンパクトに */
.hero-sub {
  font-size: clamp(13px, 1.2vw, 15px) !important;
  line-height: 1.95 !important;
  margin-bottom: var(--sp-4) !important;
  max-width: 600px;
}

/* ブランドサブと希少性バッジを統合的に小さく */
.hero-brand-sub {
  margin-top: var(--sp-3) !important;
  padding-top: var(--sp-3) !important;
  font-size: 12px !important;
  letter-spacing: 0.1em !important;
}
.scarcity-badge.in-hero {
  margin-top: var(--sp-3) !important;
  font-size: 11.5px !important;
  padding: 6px 14px !important;
}

/* メタ情報は1行コンパクト */
.hero-meta {
  margin-top: var(--sp-3) !important;
  font-size: 10.5px !important;
}

@media (max-width: 768px) {
  .hero { min-height: auto !important; }
  .hero-catch-image { max-width: 100% !important; }
}

/* ============================================
   Hero Catch Brand Signature (v2.6.1+)
   「— アスパートナー —」のブランド署名スタイル
   ============================================ */
.hero-catch-brand {
  font-family: var(--mincho);
  font-size: clamp(14px, 1.6vw, 20px);
  color: var(--gold-bright);
  letter-spacing: 0.6em;
  margin-top: var(--sp-3);
  font-weight: 400;
  opacity: 0.85;
  text-shadow: 0 0 16px rgba(226, 199, 154, 0.35);
}
@media (max-width: 768px) {
  .hero-catch-brand { font-size: 13px; letter-spacing: 0.4em; }
}

/* ============================================
   Valuation LP Intro Section (v2.7.0+)
   投資家目線で売却するということ・物件タイプ別リード
   ============================================ */
.sell-intro {
  background: linear-gradient(180deg, var(--paper) 0%, var(--cream) 100%);
}
.sell-intro-inner {
  max-width: 980px;
  margin: 0 auto;
  padding: 0 var(--sp-4);
}
.sell-intro-h {
  font-family: var(--mincho-display);
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  line-height: 1.55;
  text-align: center;
  margin: var(--sp-3) 0 var(--sp-7);
}
.sell-intro-h em {
  font-style: normal;
  color: var(--gold-deep);
}
.sell-intro-p {
  font-family: var(--mincho);
  font-size: 15px;
  line-height: 2.05;
  color: var(--text);
  letter-spacing: 0.05em;
  margin: 0 0 var(--sp-5);
}
.sell-intro-p strong {
  color: var(--gold-deep);
  font-weight: 600;
}

.sell-intro-types {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-5);
  margin: var(--sp-7) 0 var(--sp-6);
}
.sell-intro-type {
  background: var(--white);
  border: 1px solid var(--line-soft);
  border-left: 3px solid var(--gold);
  padding: var(--sp-5) var(--sp-6);
}
.sell-intro-type-tag {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold-deep);
  letter-spacing: 0.32em;
  margin-bottom: var(--sp-2);
}
.sell-intro-type-h {
  font-family: var(--mincho-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--ink-deep);
  margin: 0 0 var(--sp-3);
  letter-spacing: 0.04em;
  line-height: 1.5;
}
.sell-intro-type-p {
  font-family: var(--mincho);
  font-size: 13px;
  line-height: 1.95;
  color: var(--text);
  letter-spacing: 0.04em;
  margin: 0;
}
.sell-intro-type-p strong {
  color: var(--gold-deep);
  font-weight: 600;
}

.sell-intro-foot {
  text-align: center;
  font-family: var(--mincho);
  font-size: 13.5px;
  color: var(--text);
  line-height: 1.95;
  margin: var(--sp-6) 0 0;
  letter-spacing: 0.04em;
}
.sell-intro-link {
  display: inline-block;
  margin-top: var(--sp-2);
  font-family: var(--mincho);
  font-size: 14px;
  color: var(--gold-deep);
  border-bottom: 1px solid var(--gold);
  padding-bottom: 2px;
  letter-spacing: 0.06em;
  text-decoration: none;
}
@media (max-width: 768px) {
  .sell-intro-types { grid-template-columns: 1fr; }
}

/* ============================================
   Valuation Sales Decision LP (v2.8.0+)
   不安解消ブロック・中心メッセージ・物件タイプ
   ============================================ */

/* === 不安解消ブロック === */
.sell-relief-inner { max-width: 1100px; margin: 0 auto; padding: 0 var(--sp-4); }
.sell-relief-h {
  font-family: var(--mincho-display);
  font-size: clamp(22px, 2.8vw, 32px);
  font-weight: 600;
  color: var(--ink-deep);
  line-height: 1.6;
  letter-spacing: 0.04em;
  text-align: center;
  margin: var(--sp-3) 0 var(--sp-5);
}
.sell-relief-p {
  font-family: var(--mincho);
  font-size: 15px;
  line-height: 2.05;
  color: var(--text);
  letter-spacing: 0.05em;
  margin: 0 0 var(--sp-4);
  text-align: center;
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}
.sell-relief-p strong { color: var(--gold-deep); font-weight: 600; }
.sell-relief-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
  margin-top: var(--sp-7);
}
.sell-relief-item {
  background: var(--white);
  border: 1px solid var(--line-soft);
  padding: var(--sp-5);
  position: relative;
}
.sell-relief-num {
  position: absolute;
  top: -14px;
  left: var(--sp-4);
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 22px;
  font-weight: 500;
  color: var(--gold-deep);
  background: var(--cream);
  padding: 0 8px;
}
.sell-relief-item-h {
  font-family: var(--mincho-display);
  font-size: 15.5px;
  font-weight: 600;
  color: var(--ink-deep);
  line-height: 1.55;
  margin: var(--sp-3) 0 var(--sp-3);
  letter-spacing: 0.04em;
}
.sell-relief-item-p {
  font-family: var(--mincho);
  font-size: 13px;
  line-height: 1.95;
  color: var(--text);
  letter-spacing: 0.04em;
  margin: 0;
}
.sell-relief-item-p strong { color: var(--gold-deep); font-weight: 600; }
@media (max-width: 1024px) { .sell-relief-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .sell-relief-grid { grid-template-columns: 1fr; } }

/* === 売却判断の中心メッセージ === */
.sell-core-inner { max-width: 880px; margin: 0 auto; padding: 0 var(--sp-4); text-align: center; }
.sell-core-h {
  font-family: var(--mincho-display);
  font-size: clamp(22px, 3vw, 34px);
  font-weight: 600;
  color: var(--ink-deep);
  line-height: 1.55;
  letter-spacing: 0.04em;
  margin: var(--sp-3) 0 var(--sp-6);
}
.sell-core-h em { font-style: normal; color: var(--gold-deep); }
.sell-core-p {
  font-family: var(--mincho);
  font-size: 15px;
  line-height: 2.1;
  color: var(--text);
  letter-spacing: 0.05em;
  text-align: left;
  margin: 0 0 var(--sp-5);
}
.sell-core-p strong { color: var(--gold-deep); font-weight: 600; }

/* === 対応物件タイプ === */
.sell-types-inner { max-width: 1240px; margin: 0 auto; padding: 0 var(--sp-4); }
.sell-types-h {
  font-family: var(--mincho-display);
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  text-align: center;
  margin: var(--sp-3) 0 var(--sp-4);
}
.sell-types-h em { font-style: normal; color: var(--gold-deep); }
.sell-types-lead {
  font-family: var(--mincho);
  font-size: 14.5px;
  line-height: 1.95;
  color: var(--text-mid);
  letter-spacing: 0.05em;
  text-align: center;
  max-width: 720px;
  margin: 0 auto var(--sp-7);
}
.sell-types-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
}
.sell-types-card {
  background: var(--white);
  border: 1px solid var(--line-soft);
  padding: var(--sp-5);
  border-top: 3px solid var(--gold);
}
.sell-types-tag {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold-deep);
  letter-spacing: 0.32em;
  margin-bottom: var(--sp-2);
  font-weight: 500;
}
.sell-types-card-h {
  font-family: var(--mincho-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--ink-deep);
  letter-spacing: 0.04em;
  line-height: 1.5;
  margin: 0 0 var(--sp-3);
}
.sell-types-card-p {
  font-family: var(--mincho);
  font-size: 13px;
  line-height: 1.95;
  color: var(--text);
  letter-spacing: 0.04em;
  margin: 0 0 var(--sp-3);
}
.sell-types-card-p strong { color: var(--gold-deep); font-weight: 600; }
.sell-types-card-keys {
  font-family: var(--mincho);
  font-size: 11.5px;
  color: var(--text-soft);
  letter-spacing: 0.08em;
  margin: 0;
  padding-top: var(--sp-3);
  border-top: 1px dashed var(--line-soft);
}
@media (max-width: 1024px) { .sell-types-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .sell-types-grid { grid-template-columns: 1fr; } }

/* ======================================================
   sell-decision (保有継続 vs 売却 · 10年比較)
   ====================================================== */
.sell-decision-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 var(--sp-4);
}
.sell-decision-h {
  font-family: var(--mincho-display);
  font-size: clamp(22px, 3vw, 34px);
  line-height: 1.55;
  font-weight: 600;
  letter-spacing: 0.01em;
  text-align: center;
  margin: var(--sp-3) 0 var(--sp-4);
  color: var(--ink-1);
}
.sell-decision-h em {
  font-style: normal;
  background: linear-gradient(180deg, transparent 65%, rgba(196,156,90,0.22) 65%);
  padding: 0 0.08em;
}
.sell-decision-lead {
  max-width: 880px;
  margin: 0 auto var(--sp-6);
  text-align: center;
  font-size: 15.5px;
  line-height: 1.95;
  color: var(--ink-2);
}
.sell-decision-lead strong { color: var(--gold-deep); font-weight: 600; }
.sell-decision-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-5);
  margin-bottom: var(--sp-6);
}
.sell-decision-col {
  background: #fff;
  border: 1px solid var(--line-soft);
  border-radius: 10px;
  padding: var(--sp-5);
  position: relative;
}
.sell-decision-col-hold { border-top: 3px solid #B8B8B8; }
.sell-decision-col-sell { border-top: 3px solid var(--gold-deep); }
.sell-decision-col-tag {
  font-family: var(--serif-en);
  font-size: 12px;
  letter-spacing: 0.14em;
  color: var(--ink-3);
  margin-bottom: var(--sp-2);
  text-transform: uppercase;
}
.sell-decision-col-h {
  font-family: var(--mincho-display);
  font-size: 19px;
  line-height: 1.6;
  font-weight: 600;
  color: var(--ink-1);
  margin: 0 0 var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom: 1px dashed var(--line-soft);
}
.sell-decision-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-4);
}
.sell-decision-list li {
  font-size: 14.5px;
  line-height: 1.85;
  color: var(--ink-2);
  padding: var(--sp-2) 0;
  border-bottom: 1px dotted var(--line-soft);
}
.sell-decision-list li:last-child { border-bottom: none; }
.sell-decision-list li strong {
  display: block;
  color: var(--ink-1);
  font-size: 13.5px;
  font-weight: 600;
  margin-bottom: 2px;
  letter-spacing: 0.02em;
}
.sell-decision-col-note {
  font-size: 13px;
  color: var(--ink-3);
  margin: var(--sp-2) 0 0;
  padding-top: var(--sp-3);
  border-top: 1px dashed var(--line-soft);
  font-style: italic;
}
.sell-decision-note {
  font-size: 12.5px;
  line-height: 1.85;
  color: var(--ink-3);
  text-align: center;
  max-width: 920px;
  margin: 0 auto;
}
@media (max-width: 860px) {
  .sell-decision-grid { grid-template-columns: 1fr; }
}

/* ======================================================
   sell-aftertax (税引後の手残り · 試算プロセス)
   ====================================================== */
.sell-aftertax-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 var(--sp-4);
}
.sell-aftertax-h {
  font-family: var(--mincho-display);
  font-size: clamp(22px, 3vw, 34px);
  line-height: 1.55;
  font-weight: 600;
  text-align: center;
  margin: var(--sp-3) 0 var(--sp-4);
  color: var(--ink-1);
  letter-spacing: 0.01em;
}
.sell-aftertax-h em {
  font-style: normal;
  background: linear-gradient(180deg, transparent 65%, rgba(196,156,90,0.22) 65%);
  padding: 0 0.08em;
}
.sell-aftertax-lead {
  max-width: 860px;
  margin: 0 auto var(--sp-6);
  text-align: center;
  font-size: 15.5px;
  line-height: 1.95;
  color: var(--ink-2);
}
.sell-aftertax-flow {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}
.sell-aftertax-step {
  display: grid;
  grid-template-columns: 70px 1fr;
  gap: var(--sp-4);
  align-items: flex-start;
  background: #fff;
  border: 1px solid var(--line-soft);
  border-left: 3px solid var(--gold-soft);
  border-radius: 8px;
  padding: var(--sp-4);
}
.sell-aftertax-step-final {
  border-left: 3px solid var(--gold-deep);
  background: linear-gradient(180deg, #FFFCF3 0%, #FFF8E5 100%);
}
.sell-aftertax-step-num {
  font-family: var(--serif-en);
  font-size: 36px;
  font-weight: 400;
  color: var(--gold-deep);
  line-height: 1;
  text-align: center;
  padding-top: 4px;
}
.sell-aftertax-step-final .sell-aftertax-step-num {
  font-size: 42px;
  font-weight: 600;
}
.sell-aftertax-step-body { min-width: 0; }
.sell-aftertax-step-h {
  font-family: var(--mincho-display);
  font-size: 17px;
  font-weight: 600;
  margin: 0 0 var(--sp-2);
  color: var(--ink-1);
  letter-spacing: 0.02em;
}
.sell-aftertax-step-final .sell-aftertax-step-h {
  font-size: 19px;
  color: var(--gold-deep);
}
.sell-aftertax-step-p {
  font-size: 14px;
  line-height: 1.85;
  color: var(--ink-2);
  margin: 0;
}
.sell-aftertax-step-p strong { color: var(--gold-deep); font-weight: 600; }
.sell-aftertax-note {
  font-size: 12.5px;
  line-height: 1.85;
  color: var(--ink-3);
  text-align: center;
  max-width: 920px;
  margin: 0 auto;
}
.sell-aftertax-note strong { color: var(--ink-2); font-weight: 600; }
@media (max-width: 640px) {
  .sell-aftertax-step { grid-template-columns: 50px 1fr; gap: var(--sp-3); padding: var(--sp-3); }
  .sell-aftertax-step-num { font-size: 28px; }
  .sell-aftertax-step-final .sell-aftertax-step-num { font-size: 32px; }
}


/* ====================================================================
   Page-Valuation (.val-*) — 売却LP 専用スタイル (v2.16.0)
   ==================================================================== */
.val-page { color:#1a1a1a; font-family:"Shippori Mincho B1","Noto Serif JP",serif; }
.val-page em { font-style:normal; color:#B08855; }
.val-page strong { color:#B08855; font-weight:600; }

.val-hero { position:relative; padding:140px 24px 100px; text-align:center; color:#fff; background:linear-gradient(180deg,rgba(11,21,38,0.86) 0%,rgba(11,21,38,0.68) 45%,rgba(11,21,38,0.88) 100%),url('../images/hero/fukuoka-skyline.jpg') center/cover no-repeat; }
.val-hero-eyebrow { font-family:"EB Garamond",serif; font-style:italic; font-size:13px; letter-spacing:0.32em; color:#E2C79A; margin-bottom:24px; text-shadow:0 1px 12px rgba(0,0,0,0.4); }
.val-hero-h1 { font-family:"Shippori Mincho B1","Noto Serif JP",serif; font-size:clamp(28px,4.2vw,52px); line-height:1.7; font-weight:600; letter-spacing:0.04em; margin:0 auto 32px; max-width:1000px; color:#fff; text-shadow:0 2px 20px rgba(0,0,0,0.55); }
.val-hero-h1 em { font-style:normal; color:#E8CEA0; }
.val-hero-sub { font-family:"Shippori Mincho B1",serif; font-size:clamp(15px,1.5vw,17px); line-height:2.0; max-width:760px; margin:0 auto 40px; color:rgba(255,255,255,0.92); letter-spacing:0.04em; text-shadow:0 1px 14px rgba(0,0,0,0.5); }
.val-hero-cta { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; margin-bottom:32px; }
.val-btn { display:inline-block; padding:16px 36px; font-size:14px; letter-spacing:0.14em; text-decoration:none; transition:all 0.2s; border:1px solid; min-width:220px; text-align:center; font-family:"Shippori Mincho B1",serif; }
.val-btn-primary { background:#E2C79A; color:#0E1B2E; border-color:#E2C79A; }
.val-btn-primary:hover { background:#F2D9A8; }
.val-btn-outline { background:transparent; color:#E2C79A; border-color:rgba(226,199,154,0.5); }
.val-btn-outline:hover { border-color:#E2C79A; background:rgba(226,199,154,0.08); }
.val-hero-trust { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; max-width:780px; margin:0 auto; }
.val-hero-trust span { font-size:12px; padding:6px 14px; border:1px solid rgba(226,199,154,0.4); border-radius:2px; letter-spacing:0.08em; color:rgba(255,255,255,0.92); }

.val-section { padding:96px 24px; max-width:1180px; margin:0 auto; }
.val-section-cream { background:#FAF7F0; max-width:none; padding-left:24px; padding-right:24px; }
.val-section-cream > * { max-width:1180px; margin-left:auto; margin-right:auto; }
.val-section-dark  { background:#0E1B2E; color:#fff; }
.val-eyebrow { font-family:"EB Garamond",serif; font-style:italic; font-size:13px; letter-spacing:0.28em; color:#B08855; text-align:center; margin-bottom:18px; text-transform:uppercase; }
.val-section-dark .val-eyebrow { color:#E2C79A; }
.val-h2 { font-family:"Shippori Mincho B1",serif; font-size:clamp(24px,3vw,36px); font-weight:500; line-height:1.6; letter-spacing:0.04em; text-align:center; margin:0 0 56px; }
.val-h2 em { background:linear-gradient(180deg,transparent 65%,rgba(176,136,85,0.22) 65%); padding:0 0.08em; }
.val-section-dark .val-h2 { color:#fff; }
.val-lead { font-family:"Shippori Mincho B1",serif; font-size:15.5px; line-height:2.1; text-align:center; max-width:780px; margin:0 auto 56px; color:#3a3a3a; letter-spacing:0.04em; }
.val-section-dark .val-lead { color:rgba(255,255,255,0.85); }

.val-relief-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.val-relief-card { background:#fff; padding:32px 28px; border:1px solid rgba(176,136,85,0.18); border-top:3px solid #B08855; }
.val-relief-num { font-family:"EB Garamond",serif; font-style:italic; font-size:13px; color:#B08855; letter-spacing:0.18em; margin-bottom:14px; }
.val-relief-h { font-family:"Shippori Mincho B1",serif; font-size:16.5px; font-weight:600; line-height:1.65; margin:0 0 10px; color:#1a1a1a; }
.val-relief-p { font-size:13.5px; line-height:1.95; color:#5a5a5a; margin:0; font-family:"Shippori Mincho B1",serif; }

.val-deck-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:18px; }
.val-deck-card { background:#fff; padding:28px 20px; text-align:center; border:1px solid rgba(176,136,85,0.18); }
.val-deck-num { font-family:"EB Garamond",serif; font-style:italic; font-size:32px; color:#B08855; margin-bottom:12px; line-height:1; }
.val-deck-h { font-family:"Shippori Mincho B1",serif; font-size:14.5px; font-weight:600; margin:0 0 8px; color:#1a1a1a; line-height:1.5; }
.val-deck-p { font-size:12px; line-height:1.7; color:#666; margin:0; font-family:"Shippori Mincho B1",serif; }

.val-type-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.val-type-card { background:#fff; padding:36px 32px; border:1px solid rgba(176,136,85,0.2); position:relative; }
.val-type-tag { font-family:"EB Garamond",serif; font-style:italic; font-size:11px; letter-spacing:0.22em; color:#B08855; margin-bottom:10px; text-transform:uppercase; }
.val-type-h { font-family:"Shippori Mincho B1",serif; font-size:21px; font-weight:600; margin:0 0 20px; color:#0E1B2E; padding-bottom:14px; border-bottom:1px solid rgba(176,136,85,0.2); }
.val-type-row { display:grid; grid-template-columns:90px 1fr; gap:12px; padding:9px 0; font-size:13.5px; line-height:1.7; font-family:"Shippori Mincho B1",serif; }
.val-type-row + .val-type-row { border-top:1px dotted rgba(176,136,85,0.18); }
.val-type-key { color:#B08855; font-weight:600; font-size:12px; letter-spacing:0.06em; }
.val-type-val { color:#3a3a3a; }

.val-compare-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; max-width:980px; margin:0 auto; }
.val-compare-card { background:#fff; padding:40px 36px; border:1px solid rgba(176,136,85,0.22); }
.val-compare-card-featured { background:#0E1B2E; color:#fff; border-color:#B08855; }
.val-compare-en { font-family:"EB Garamond",serif; font-style:italic; font-size:11px; letter-spacing:0.28em; color:#B08855; margin-bottom:14px; text-transform:uppercase; }
.val-compare-card-featured .val-compare-en { color:#E2C79A; }
.val-compare-h { font-family:"Shippori Mincho B1",serif; font-size:24px; font-weight:600; margin:0 0 12px; color:#0E1B2E; }
.val-compare-card-featured .val-compare-h { color:#fff; }
.val-compare-h em { color:#B08855; }
.val-compare-card-featured .val-compare-h em { color:#E2C79A; }
.val-compare-lead { font-size:13.5px; line-height:1.95; color:#555; margin:0 0 24px; font-family:"Shippori Mincho B1",serif; }
.val-compare-card-featured .val-compare-lead { color:rgba(255,255,255,0.78); }
.val-compare-list { padding:18px 0; border-top:1px solid rgba(176,136,85,0.2); border-bottom:1px solid rgba(176,136,85,0.2); }
.val-compare-card-featured .val-compare-list { border-color:rgba(226,199,154,0.25); }
.val-compare-list dl { display:grid; grid-template-columns:100px 1fr; gap:10px 14px; font-size:13px; line-height:1.85; margin:0; font-family:"Shippori Mincho B1",serif; }
.val-compare-list dt { color:#B08855; font-weight:600; }
.val-compare-card-featured .val-compare-list dt { color:#E2C79A; }
.val-compare-list dd { color:#3a3a3a; margin:0; }
.val-compare-card-featured .val-compare-list dd { color:rgba(255,255,255,0.82); }
.val-compare-card .val-btn { width:100%; margin-top:22px; box-sizing:border-box; }

.val-flow { max-width:840px; margin:0 auto; }
.val-flow-item { display:grid; grid-template-columns:64px 1fr; gap:28px; padding:24px 0; border-bottom:1px dashed rgba(176,136,85,0.25); }
.val-flow-item:last-child { border-bottom:none; }
.val-flow-num { font-family:"EB Garamond",serif; font-style:italic; font-size:36px; color:#B08855; line-height:1; padding-top:4px; }
.val-flow-h { font-family:"Shippori Mincho B1",serif; font-size:17px; font-weight:600; margin:0 0 8px; color:#0E1B2E; }
.val-flow-p { font-size:13.5px; line-height:1.95; color:#555; margin:0; font-family:"Shippori Mincho B1",serif; }
.val-flow-time { display:inline-block; font-family:"EB Garamond",serif; font-style:italic; font-size:11.5px; color:#B08855; letter-spacing:0.14em; margin-top:6px; }

.val-faq { max-width:880px; margin:0 auto; }
.val-faq-item { background:#fff; padding:24px 28px; margin-bottom:14px; border:1px solid rgba(176,136,85,0.18); border-left:3px solid #B08855; }
.val-faq-q { font-family:"Shippori Mincho B1",serif; font-size:15.5px; font-weight:600; color:#0E1B2E; margin:0 0 10px; padding-left:32px; position:relative; }
.val-faq-q::before { content:"Q."; font-family:"EB Garamond",serif; font-style:italic; color:#B08855; position:absolute; left:0; top:0; font-weight:500; }
.val-faq-a { font-family:"Shippori Mincho B1",serif; font-size:14px; line-height:1.95; color:#555; margin:0; padding-left:32px; position:relative; }
.val-faq-a::before { content:"A."; font-family:"EB Garamond",serif; font-style:italic; color:#B08855; position:absolute; left:0; top:0; font-weight:500; }

.val-final { padding:90px 24px; background:radial-gradient(circle at 0% 0%,rgba(226,199,154,0.10) 0%,transparent 50%),linear-gradient(135deg,#0E1B2E 0%,#14243A 50%,#0E1B2E 100%); color:#fff; text-align:center; }
.val-final-eyebrow { font-family:"EB Garamond",serif; font-style:italic; font-size:13px; letter-spacing:0.32em; color:#E2C79A; margin-bottom:24px; text-transform:uppercase; }
.val-final-h { font-family:"Shippori Mincho B1",serif; font-size:clamp(26px,3.4vw,40px); font-weight:600; line-height:1.7; margin:0 0 28px; color:#fff; }
.val-final-h em { color:#E2C79A; font-style:normal; }
.val-final-div { width:56px; height:1px; background:rgba(226,199,154,0.6); margin:0 auto 28px; }
.val-final-lead { font-size:15px; line-height:2.0; color:rgba(255,255,255,0.85); max-width:680px; margin:0 auto 32px; font-family:"Shippori Mincho B1",serif; }
.val-final-meta { display:flex; gap:20px; justify-content:center; flex-wrap:wrap; padding:14px 0; border-top:1px dashed rgba(226,199,154,0.2); border-bottom:1px dashed rgba(226,199,154,0.2); margin-bottom:36px; font-family:"EB Garamond",serif; font-style:italic; font-size:12.5px; color:rgba(255,255,255,0.72); letter-spacing:0.16em; }
.val-final .val-btn { min-width:300px; }
.val-final-tel { font-family:"Shippori Mincho B1",serif; font-size:13px; color:rgba(255,255,255,0.6); margin-top:32px; letter-spacing:0.06em; }
.val-final-tel a { color:#E2C79A; font-family:"EB Garamond",serif; font-size:17px; font-weight:500; letter-spacing:0.08em; text-decoration:none; border-bottom:1px solid rgba(226,199,154,0.45); padding:0 4px 2px; margin:0 6px; }

@media (max-width:900px) {
  .val-relief-grid { grid-template-columns:1fr; }
  .val-deck-grid { grid-template-columns:repeat(2,1fr); }
  .val-type-grid { grid-template-columns:1fr; }
  .val-compare-grid { grid-template-columns:1fr; }
  .val-section { padding:64px 20px; }
  .val-hero { padding:96px 20px 72px; }
}


/* ====================================================================
   Page-Valuation LP additions (v2.17.0)
   - val-stats / val-aftertax / val-pricing / val-ward-table
   - val-buyer / val-why / val-commit / val-ceo / val-voice
   ==================================================================== */

/* 実績バー */
.val-stats { background:#0E1B2E; padding:48px 24px; }
.val-stats-inner { max-width:1180px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; color:#fff; }
.val-stat-item { padding:8px 0; border-right:1px solid rgba(226,199,154,0.18); }
.val-stat-item:last-child { border-right:none; }
.val-stat-num { font-family:"EB Garamond",serif; font-size:clamp(34px,4vw,52px); font-weight:500; line-height:1; color:#E2C79A; letter-spacing:0.02em; }
.val-stat-num .val-stat-unit { font-size:14px; font-style:italic; color:rgba(226,199,154,0.78); margin-left:4px; letter-spacing:0.08em; }
.val-stat-label { font-family:"Shippori Mincho B1",serif; font-size:13px; margin-top:12px; color:rgba(255,255,255,0.78); letter-spacing:0.14em; }
.val-stat-label small { display:block; font-size:10.5px; color:rgba(255,255,255,0.5); margin-top:4px; letter-spacing:0.1em; }
@media (max-width:760px) {
  .val-stats-inner { grid-template-columns:repeat(2,1fr); gap:20px 16px; }
  .val-stat-item:nth-child(2) { border-right:none; }
}

/* 税引後手残り */
.val-aftertax-flow { max-width:880px; margin:0 auto 32px; display:flex; flex-direction:column; gap:14px; }
.val-aftertax-step { display:grid; grid-template-columns:64px 1fr; gap:24px; background:#fff; border:1px solid rgba(176,136,85,0.18); border-left:3px solid rgba(176,136,85,0.5); padding:22px 28px; }
.val-aftertax-step-final { border-left:3px solid #B08855; background:linear-gradient(180deg,#FFFCF3 0%,#FFF8E5 100%); }
.val-aftertax-num { font-family:"EB Garamond",serif; font-style:italic; font-size:30px; color:#B08855; line-height:1; padding-top:4px; text-align:center; }
.val-aftertax-step-final .val-aftertax-num { font-size:36px; font-weight:600; }
.val-aftertax-h { font-family:"Shippori Mincho B1",serif; font-size:16px; font-weight:600; color:#0E1B2E; margin:0 0 6px; letter-spacing:0.04em; }
.val-aftertax-step-final .val-aftertax-h { font-size:18px; color:#8e6c2a; }
.val-aftertax-p { font-family:"Shippori Mincho B1",serif; font-size:13.5px; line-height:1.9; color:#555; margin:0; }
.val-aftertax-p strong { color:#B08855; }
.val-note { text-align:center; font-size:12px; line-height:1.8; color:#888; max-width:880px; margin:0 auto; font-family:"Shippori Mincho B1",serif; }

/* 査定根拠 7指標 */
.val-pricing-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.val-pricing-grid > *:first-child { grid-column:auto; }
.val-pricing-card { background:#fff; padding:28px 22px; border:1px solid rgba(176,136,85,0.18); }
.val-pricing-num { font-family:"EB Garamond",serif; font-style:italic; font-size:13px; color:#B08855; letter-spacing:0.18em; margin-bottom:12px; }
.val-pricing-h { font-family:"Shippori Mincho B1",serif; font-size:15.5px; font-weight:600; margin:0 0 10px; color:#1a1a1a; line-height:1.55; }
.val-pricing-p { font-family:"Shippori Mincho B1",serif; font-size:12.5px; line-height:1.85; color:#5a5a5a; margin:0; }
@media (max-width:900px) { .val-pricing-grid { grid-template-columns:repeat(2,1fr); } }

/* 7区テーブル */
.val-ward-table-wrap { max-width:1080px; margin:0 auto 24px; overflow-x:auto; }
.val-ward-table { width:100%; border-collapse:collapse; background:#fff; font-family:"Shippori Mincho B1",serif; font-size:13.5px; }
.val-ward-table thead { background:#0E1B2E; color:#fff; }
.val-ward-table th { padding:16px 18px; text-align:left; font-weight:500; letter-spacing:0.06em; font-size:12.5px; border-right:1px solid rgba(226,199,154,0.18); }
.val-ward-table th:last-child { border-right:none; text-align:center; }
.val-ward-table td { padding:18px; border-bottom:1px solid rgba(176,136,85,0.14); color:#3a3a3a; line-height:1.7; vertical-align:top; }
.val-ward-table td:last-child { text-align:center; vertical-align:middle; }
.val-ward-table tr:nth-child(even) td { background:#FAF7F0; }
.val-ward-table tr:hover td { background:rgba(226,199,154,0.08); }
.val-ward-name { font-weight:600; color:#0E1B2E; min-width:90px; }
.val-ward-name small { display:block; font-family:"EB Garamond",serif; font-style:italic; color:#888; font-size:11px; margin-top:2px; }
.val-ward-table small { color:#777; font-size:11px; }
.val-rate { display:inline-block; padding:5px 14px; border-radius:999px; font-family:"Shippori Mincho B1",serif; font-size:12px; font-weight:500; letter-spacing:0.08em; line-height:1.4; white-space:nowrap; }
.val-rate-high { background:linear-gradient(135deg,#f8e7c4 0%,#e2c79a 100%); color:#6b4a1c; border:1px solid #d6b06a; }
.val-rate-mid { background:rgba(226,199,154,0.18); color:#8e6c2a; border:1px solid rgba(214,176,106,0.45); }
.val-rate-low { background:rgba(0,0,0,0.03); color:#888; border:1px solid rgba(0,0,0,0.08); }

/* 買主ネットワーク */
.val-buyer-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:18px; }
.val-buyer-card { background:#fff; padding:28px 22px; border:1px solid rgba(176,136,85,0.18); border-top:3px solid #B08855; }
.val-buyer-num { font-family:"EB Garamond",serif; font-style:italic; font-size:22px; color:#B08855; line-height:1; margin-bottom:8px; }
.val-buyer-tag { font-family:"EB Garamond",serif; font-style:italic; font-size:10.5px; letter-spacing:0.18em; color:#888; margin-bottom:12px; text-transform:uppercase; }
.val-buyer-h { font-family:"Shippori Mincho B1",serif; font-size:15px; font-weight:600; margin:0 0 12px; color:#1a1a1a; line-height:1.5; }
.val-buyer-p { font-family:"Shippori Mincho B1",serif; font-size:12.5px; line-height:1.85; color:#5a5a5a; margin:0; }
.val-buyer-p strong { color:#B08855; }
@media (max-width:1100px) { .val-buyer-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px)  { .val-buyer-grid { grid-template-columns:1fr; } }

/* outlined dark button (light bg context) */
.val-btn-outline-dark { background:transparent; color:#0E1B2E; border-color:rgba(176,136,85,0.5); }
.val-btn-outline-dark:hover { border-color:#B08855; background:rgba(226,199,154,0.1); }

/* 3つの強み */
.val-why-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.val-why-card { background:#fff; padding:40px 32px; border:1px solid rgba(176,136,85,0.2); position:relative; }
.val-why-card-highlight { background:linear-gradient(180deg,#FFFCF3 0%,#fff 100%); border-color:#B08855; border-width:1px; box-shadow:0 12px 30px rgba(176,136,85,0.10); }
.val-why-num { font-family:"EB Garamond",serif; font-style:italic; font-size:32px; color:#B08855; line-height:1; margin-bottom:8px; }
.val-why-tag { font-family:"EB Garamond",serif; font-style:italic; font-size:11px; letter-spacing:0.22em; color:#888; margin-bottom:16px; text-transform:uppercase; }
.val-why-h { font-family:"Shippori Mincho B1",serif; font-size:18px; font-weight:600; line-height:1.6; margin:0 0 16px; color:#0E1B2E; }
.val-why-h em { background:linear-gradient(180deg,transparent 65%,rgba(176,136,85,0.22) 65%); padding:0 0.08em; font-style:normal; color:inherit; }
.val-why-p { font-family:"Shippori Mincho B1",serif; font-size:13.5px; line-height:1.95; color:#555; margin:0 0 18px; }
.val-why-p strong { color:#B08855; }
.val-why-list { list-style:none; padding:0; margin:18px 0 0; border-top:1px dashed rgba(176,136,85,0.25); padding-top:18px; }
.val-why-list li { font-family:"Shippori Mincho B1",serif; font-size:13px; line-height:1.85; color:#666; padding:5px 0 5px 20px; position:relative; }
.val-why-list li::before { content:""; width:6px; height:6px; background:#B08855; border-radius:50%; position:absolute; left:0; top:14px; }
@media (max-width:900px) { .val-why-grid { grid-template-columns:1fr; } }

/* 4つのお約束 */
.val-commit-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.val-commit-card { background:#fff; padding:32px 26px; border:1px solid rgba(176,136,85,0.2); text-align:center; }
.val-commit-num { font-family:"EB Garamond",serif; font-style:italic; font-size:34px; color:#B08855; line-height:1; margin-bottom:8px; }
.val-commit-tag { font-family:"EB Garamond",serif; font-style:italic; font-size:10.5px; letter-spacing:0.18em; color:#888; margin-bottom:16px; text-transform:uppercase; }
.val-commit-h { font-family:"Shippori Mincho B1",serif; font-size:15px; font-weight:600; line-height:1.6; margin:0 0 14px; color:#0E1B2E; padding-bottom:14px; border-bottom:1px solid rgba(176,136,85,0.2); }
.val-commit-p { font-family:"Shippori Mincho B1",serif; font-size:12.5px; line-height:1.9; color:#5a5a5a; margin:0; text-align:left; }
@media (max-width:900px) { .val-commit-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px) { .val-commit-grid { grid-template-columns:1fr; } }

/* 代表メッセージ */
.val-ceo { position:relative; display:grid; grid-template-columns:300px 1fr; gap:56px; max-width:1080px; margin:0 auto; align-items:center; background:#fff; padding:56px 60px; border:1px solid rgba(176,136,85,0.2); border-radius:4px; box-shadow:0 24px 60px rgba(14,27,46,0.07); overflow:hidden; }
.val-ceo::before { content:""; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,#c9a567,#e2c79a,#c9a567); }
.val-ceo-photo { width:300px; height:380px; background-size:cover; background-position:center top; background-color:#FAF7F0; border-radius:3px; box-shadow:0 16px 36px rgba(14,27,46,0.16); }
.val-ceo-body { padding-top:4px; position:relative; }
.val-ceo-body::before { content:"\201C"; position:absolute; top:-42px; left:-8px; font-family:"EB Garamond",serif; font-size:96px; line-height:1; color:rgba(176,136,85,0.18); pointer-events:none; }
.val-ceo-p { font-family:"Shippori Mincho B1",serif; font-size:15px; line-height:2.15; color:#3a3a3a; margin:0 0 20px; letter-spacing:0.05em; }
.val-ceo-p:last-of-type { margin-bottom:0; }
.val-ceo-p strong { color:#B08855; }
.val-ceo-sign { margin-top:28px; padding-top:22px; border-top:1px solid rgba(176,136,85,0.25); font-family:"Shippori Mincho B1",serif; }
.val-ceo-sign strong { display:inline-block; font-size:20px; color:#0E1B2E; font-weight:600; letter-spacing:0.1em; margin-bottom:4px; }
.val-ceo-sign span { font-size:13px; color:#555; letter-spacing:0.04em; }
.val-ceo-sign small { display:block; font-size:11.5px; color:#999; line-height:1.8; margin-top:6px; letter-spacing:0.02em; }
@media (max-width:900px) {
  .val-ceo { grid-template-columns:1fr; gap:32px; padding:40px 28px; align-items:start; }
  .val-ceo-photo { width:100%; max-width:280px; height:auto; aspect-ratio:5/6; margin:0 auto; }
  .val-ceo-body::before { display:none; }
}

/* お客様の声 */
.val-voice-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; max-width:1080px; margin:0 auto 24px; }
.val-voice-card { background:#fff; padding:36px 32px; border:1px solid rgba(176,136,85,0.2); border-left:3px solid #B08855; }
.val-voice-tag { font-family:"EB Garamond",serif; font-style:italic; font-size:11px; letter-spacing:0.18em; color:#B08855; margin-bottom:18px; text-transform:uppercase; }
.val-voice-quote { font-family:"Shippori Mincho B1",serif; font-size:15px; line-height:2.05; color:#1a1a1a; margin:0 0 22px; letter-spacing:0.04em; }
.val-voice-quote strong { color:#B08855; }
.val-voice-meta { font-family:"EB Garamond",serif; font-style:italic; font-size:12px; color:#888; letter-spacing:0.1em; margin:0; padding-top:16px; border-top:1px dashed rgba(176,136,85,0.25); }
@media (max-width:760px) { .val-voice-grid { grid-template-columns:1fr; } }


/* ====================================================================
   Inheritance LP additions (v2.18.0) — val-* と併用
   - val-bars (相続税評価減) / val-timeline (10ヶ月) / val-options (3択)
   ==================================================================== */

/* 相続税評価減バー */
.val-bars { max-width:880px; margin:0 auto; background:#fff; padding:40px 36px; border:1px solid rgba(176,136,85,0.2); }
.val-bars-title { font-family:"Shippori Mincho B1",serif; font-size:16px; font-weight:600; color:#0E1B2E; text-align:center; margin:0 0 28px; letter-spacing:0.04em; }
.val-bar-row { display:grid; grid-template-columns:180px 1fr 90px; gap:16px; align-items:center; margin-bottom:14px; }
.val-bar-label { font-family:"Shippori Mincho B1",serif; font-size:13px; color:#3a3a3a; line-height:1.4; }
.val-bar-label small { display:block; font-size:10.5px; color:#999; margin-top:2px; }
.val-bar-track { background:#F0EAE0; height:34px; border-radius:2px; overflow:hidden; }
.val-bar-fill { height:100%; background:linear-gradient(90deg,#c9a567,#e2c79a); display:flex; align-items:center; justify-content:flex-end; padding-right:12px; color:#5a3e16; font-family:"EB Garamond",serif; font-style:italic; font-size:13px; font-weight:600; }
.val-bar-row.savings .val-bar-fill { background:linear-gradient(90deg,#0E1B2E,#1d3a5c); color:#E2C79A; }
.val-bar-result { font-family:"EB Garamond",serif; font-size:20px; font-weight:600; color:#0E1B2E; text-align:right; }
.val-bar-result small { font-size:11px; color:#888; margin-left:1px; }
.val-bar-row.savings .val-bar-result { color:#B08855; }
@media (max-width:760px) {
  .val-bar-row { grid-template-columns:1fr; gap:6px; margin-bottom:18px; }
  .val-bar-result { text-align:left; }
}

/* 10ヶ月タイムライン */
.val-timeline { max-width:840px; margin:0 auto; position:relative; }
.val-timeline::before { content:""; position:absolute; left:90px; top:10px; bottom:10px; width:1px; background:rgba(176,136,85,0.3); }
.val-tl-item { display:grid; grid-template-columns:80px 1fr; gap:32px; padding:0 0 32px; position:relative; }
.val-tl-item:last-child { padding-bottom:0; }
.val-tl-time { font-family:"EB Garamond",serif; font-style:italic; font-size:14px; color:#B08855; text-align:right; padding-top:2px; font-weight:500; letter-spacing:0.04em; }
.val-tl-body { position:relative; padding-left:28px; }
.val-tl-body::before { content:""; position:absolute; left:-1px; top:5px; width:11px; height:11px; border-radius:50%; background:#B08855; border:2px solid #fff; box-shadow:0 0 0 1px rgba(176,136,85,0.4); }
.val-tl-h { font-family:"Shippori Mincho B1",serif; font-size:16px; font-weight:600; color:#0E1B2E; margin:0 0 6px; }
.val-tl-p { font-family:"Shippori Mincho B1",serif; font-size:13.5px; line-height:1.9; color:#555; margin:0; }
@media (max-width:600px) {
  .val-timeline::before { left:8px; }
  .val-tl-item { grid-template-columns:1fr; gap:4px; }
  .val-tl-time { text-align:left; padding-left:28px; }
}

/* 3つの選択肢 */
.val-options-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.val-option-card { background:#fff; padding:36px 30px; border:1px solid rgba(176,136,85,0.2); text-align:center; }
.val-option-card-featured { background:#0E1B2E; color:#fff; border-color:#B08855; }
.val-option-en { font-family:"EB Garamond",serif; font-style:italic; font-size:11px; letter-spacing:0.22em; color:#B08855; margin-bottom:12px; text-transform:uppercase; }
.val-option-card-featured .val-option-en { color:#E2C79A; }
.val-option-h { font-family:"Shippori Mincho B1",serif; font-size:20px; font-weight:600; color:#0E1B2E; margin:0 0 16px; padding-bottom:14px; border-bottom:1px solid rgba(176,136,85,0.2); }
.val-option-card-featured .val-option-h { color:#fff; border-color:rgba(226,199,154,0.25); }
.val-option-p { font-family:"Shippori Mincho B1",serif; font-size:13.5px; line-height:1.95; color:#555; margin:0; text-align:left; }
.val-option-card-featured .val-option-p { color:rgba(255,255,255,0.82); }
.val-option-p strong { color:#B08855; }
.val-option-card-featured .val-option-p strong { color:#E2C79A; }
@media (max-width:900px) { .val-options-grid { grid-template-columns:1fr; } }


/* ====================================================================
   Failure-Cases LP additions (v2.19.0) — val-* と併用
   ==================================================================== */
.val-fail-list { max-width:980px; margin:0 auto; display:flex; flex-direction:column; gap:24px; }
.val-fail-card { background:#fff; border:1px solid rgba(176,136,85,0.2); border-left:3px solid #b94d3d; padding:36px 36px; display:grid; grid-template-columns:64px 1fr; gap:28px; }
.val-fail-num { font-family:"EB Garamond",serif; font-style:italic; font-size:40px; color:#b94d3d; line-height:1; padding-top:2px; }
.val-fail-h { font-family:"Shippori Mincho B1",serif; font-size:19px; font-weight:600; color:#0E1B2E; line-height:1.6; margin:0 0 14px; }
.val-fail-body { font-family:"Shippori Mincho B1",serif; font-size:14px; line-height:2.0; color:#444; margin:0 0 20px; letter-spacing:0.03em; }
.val-fail-counter { background:linear-gradient(180deg,#FFFCF3,#FFF8E5); border:1px solid rgba(176,136,85,0.3); border-radius:3px; padding:18px 22px; font-family:"Shippori Mincho B1",serif; font-size:13.5px; line-height:1.95; color:#3a3a3a; }
.val-fail-counter em { font-style:normal; color:#B08855; font-weight:600; display:block; margin-bottom:6px; font-size:12.5px; letter-spacing:0.08em; }
.val-fail-counter strong { color:#B08855; }
@media (max-width:600px) {
  .val-fail-card { grid-template-columns:1fr; gap:12px; padding:28px 24px; }
  .val-fail-num { font-size:32px; }
}
/* 中央寄せの約束ボックス */
.val-promise { max-width:880px; margin:48px auto 0; background:#0E1B2E; color:#fff; padding:48px 44px; text-align:center; border:1px solid rgba(226,199,154,0.25); }
.val-promise-en { font-family:"EB Garamond",serif; font-style:italic; font-size:12px; letter-spacing:0.32em; color:#E2C79A; margin-bottom:16px; text-transform:uppercase; }
.val-promise-h { font-family:"Shippori Mincho B1",serif; font-size:clamp(22px,2.6vw,28px); font-weight:500; line-height:1.6; margin:0 0 18px; color:#fff; }
.val-promise-h em { font-style:normal; color:#E2C79A; }
.val-promise-p { font-family:"Shippori Mincho B1",serif; font-size:14px; line-height:2.05; color:rgba(255,255,255,0.85); max-width:720px; margin:0 auto; letter-spacing:0.04em; }


/* 実績バー直下 取扱い内訳ストリップ (CODEX: 物件タイプ別分解) */
.val-stats-types { max-width:1180px; margin:28px auto 0; padding-top:24px; border-top:1px solid rgba(226,199,154,0.18); display:flex; flex-wrap:wrap; gap:10px; align-items:center; justify-content:center; }
.val-stats-types-label { font-family:"EB Garamond",serif; font-style:italic; font-size:11px; letter-spacing:0.2em; color:#E2C79A; text-transform:uppercase; margin-right:6px; }
.val-stats-types span:not(.val-stats-types-label) { font-family:"Shippori Mincho B1",serif; font-size:12px; color:rgba(255,255,255,0.82); padding:5px 13px; border:1px solid rgba(226,199,154,0.28); border-radius:999px; letter-spacing:0.04em; }
@media (max-width:600px) { .val-stats-types span:not(.val-stats-types-label) { font-size:11px; padding:4px 10px; } }


/* ====================================================================
   Valuation CV強化 (v2.22.0) — ハードル下げ / こんなご相談 / 中盤CTA帯
   ==================================================================== */
/* ヒーローCTA下の小さな補足 */
.val-hero-micro { font-family:"Shippori Mincho B1",serif; font-size:12.5px; color:rgba(255,255,255,0.75); margin:-18px 0 28px; letter-spacing:0.04em; text-shadow:0 1px 10px rgba(0,0,0,0.4); }

/* こんなご相談が多いです(自分ごと化) */
.val-cases-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.val-case-card { background:#fff; border:1px solid rgba(176,136,85,0.2); border-radius:6px; padding:26px 18px; text-align:center; transition:transform 0.2s, box-shadow 0.2s; }
.val-case-card:hover { transform:translateY(-3px); box-shadow:0 12px 28px rgba(176,136,85,0.14); }
.val-case-icon { font-family:"EB Garamond",serif; font-style:italic; font-size:13px; color:#B08855; letter-spacing:0.14em; margin-bottom:12px; }
.val-case-h { font-family:"Shippori Mincho B1",serif; font-size:14px; font-weight:600; line-height:1.6; color:#0E1B2E; margin:0; }
@media (max-width:1000px){ .val-cases-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .val-cases-grid{ grid-template-columns:1fr; } }

/* 中盤CTA帯 */
.val-midcta { max-width:1000px; margin:0 auto; background:linear-gradient(135deg,#0E1B2E 0%,#16283f 100%); border:1px solid rgba(226,199,154,0.25); border-radius:6px; padding:44px 40px; display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap; }
.val-midcta-text { flex:1; min-width:280px; }
.val-midcta-h { font-family:"Shippori Mincho B1",serif; font-size:clamp(20px,2.4vw,26px); font-weight:600; color:#fff; line-height:1.6; margin:0 0 10px; }
.val-midcta-h em { font-style:normal; color:#E8CEA0; }
.val-midcta-p { font-family:"Shippori Mincho B1",serif; font-size:13.5px; color:rgba(255,255,255,0.8); line-height:1.85; margin:0; }
.val-midcta-action { display:flex; flex-direction:column; gap:10px; align-items:stretch; min-width:240px; }
.val-midcta-note { font-family:"Shippori Mincho B1",serif; font-size:11.5px; color:rgba(255,255,255,0.6); text-align:center; margin:0; }
@media (max-width:760px){ .val-midcta{ flex-direction:column; align-items:stretch; text-align:center; padding:36px 24px; } .val-midcta-action .val-btn{ width:100%; box-sizing:border-box; } }


/* ====================================================================
   Mobile polish — LP全体をスマホで綺麗に表示 (v2.29.0)
   .val-* システム / blog-card / 実績バー / CTA をスマホ最適化
   ==================================================================== */
@media (max-width: 640px) {
  /* すべての多カラムグリッドを1カラムへ */
  .val-relief-grid, .val-deck-grid, .val-type-grid, .val-why-grid,
  .val-cases-grid, .val-pricing-grid, .val-buyer-grid, .val-commit-grid,
  .val-options-grid, .val-compare-grid, .val-voice-grid {
    grid-template-columns: 1fr !important;
  }
  .blog-grid { grid-template-columns: 1fr !important; }

  /* セクション余白を引き締め */
  .val-section { padding: 56px 18px; }
  .val-hero { padding: 84px 18px 56px; }
  .val-final { padding: 64px 18px; }

  /* 見出し・本文のサイズ調整 */
  .val-hero-h1 { font-size: clamp(24px, 7vw, 33px); line-height: 1.62; }
  .val-hero-sub { font-size: 14px; }
  .val-h2 { font-size: clamp(21px, 6vw, 28px); margin-bottom: 36px; }
  .val-lead { font-size: 14px; margin-bottom: 36px; }
  .val-final-h { font-size: clamp(22px, 6.4vw, 30px); }
  .val-final-lead { font-size: 14px; }

  /* CTAボタンは全幅・縦積み(指で押しやすく) */
  .val-hero-cta { flex-direction: column; gap: 12px; }
  .val-btn { width: 100%; min-width: 0 !important; box-sizing: border-box; padding: 15px 18px; }
  .val-final .val-btn { min-width: 0 !important; }

  /* trust pills / meta を小さめに */
  .val-hero-trust { gap: 8px; }
  .val-hero-trust span, .val-final-meta span, .val-stats-types span:not(.val-stats-types-label) { font-size: 11px; padding: 5px 11px; }
  .val-hero-micro { font-size: 12px; margin: -8px 0 24px; }

  /* 実績バー：2列維持・数字を縮小して収める */
  .val-stats { padding: 36px 16px; }
  .val-stats-inner { gap: 22px 14px; }
  .val-stat-num { font-size: 28px; }
  .val-stat-num .val-stat-unit { font-size: 12px; }
  .val-stat-label { font-size: 12px; }

  /* 代表メッセージ */
  .val-ceo { padding: 32px 20px; gap: 26px; }
  .val-ceo-p { font-size: 14px; line-height: 2.0; }

  /* 税引後フロー */
  .val-aftertax-step { grid-template-columns: 44px 1fr; gap: 14px; padding: 18px 16px; }
  .val-aftertax-num { font-size: 26px; }

  /* 7区テーブルは横スクロール(最小幅を確保) */
  .val-ward-table-wrap { -webkit-overflow-scrolling: touch; }
  .val-ward-table { min-width: 600px; }

  /* 物件タイプ行：ラベルと値を縦に */
  .val-type-row { grid-template-columns: 1fr; gap: 2px; }
  .val-type-card { padding: 28px 22px; }

  /* 評価減バー(相続)：縦並び */
  .val-bar-row { grid-template-columns: 1fr; gap: 6px; }
  .val-bars { padding: 28px 20px; }

  /* 中盤CTA帯：縦積み・ボタン全幅 */
  .val-midcta { flex-direction: column; align-items: stretch; text-align: center; padding: 32px 22px; }
  .val-midcta-action .val-btn { width: 100%; }
}

/* タブレット幅(641〜900px)の微調整 */
@media (max-width: 900px) and (min-width: 641px) {
  .val-deck-grid { grid-template-columns: repeat(2, 1fr); }
  .val-pricing-grid { grid-template-columns: repeat(2, 1fr); }
  .val-buyer-grid { grid-template-columns: repeat(2, 1fr); }
}
