/* =============================================
   /thinking/verbalization.html
   思考と言語化の構造 — そしてAIによる増幅
   長文理論記事用レイアウト
   ============================================= */

.vb-wrap {
  max-width: 820px;
  margin: 0 auto;
  padding: clamp(48px, 7vw, 88px) clamp(20px, 5vw, 48px) clamp(72px, 9vw, 110px);
}

/* English abstract (EN mode only) */
.vb-abstract {
  border: 1px solid var(--line);
  border-left: 3px solid var(--gold);
  background: var(--bg-subtle);
  border-radius: 8px;
  padding: 22px 26px;
  margin-bottom: 40px;
  font-size: 14px;
  line-height: 1.85;
  color: var(--ink-soft);
}
.vb-abstract h2 {
  font-family: var(--font-display-en);
  font-size: 15px;
  letter-spacing: 0.04em;
  color: var(--navy-deep);
  margin-bottom: 10px;
}

/* Lead / opening blockquote */
.vb-lead {
  font-size: clamp(15px, 1.6vw, 17px);
  line-height: 1.95;
  color: var(--ink-soft);
  border-left: 3px solid var(--gold);
  padding: 6px 0 6px 20px;
  margin-bottom: clamp(36px, 5vw, 52px);
}
.vb-lead strong { color: var(--navy-deep); }

/* ---- Three-part map ---- */
.vb-map {
  margin: 0 auto clamp(48px, 7vw, 72px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}
.vb-map-box {
  width: 100%;
  max-width: 560px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 18px 22px;
  background: var(--bg-card, #fff);
  position: relative;
}
.vb-map-box.p1 { border-top: 4px solid var(--gold); }
.vb-map-box.p2 { border-top: 4px solid #5E8B6E; }
.vb-map-box.p3 { border-top: 4px solid #6F88B5; }
.vb-map-box .vb-map-no {
  font-family: var(--font-display-en);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-dim);
  font-weight: 700;
}
.vb-map-box .vb-map-ttl {
  font-family: var(--font-display-jp);
  font-size: clamp(16px, 2vw, 19px);
  font-weight: 700;
  color: var(--navy-deep);
  margin: 4px 0 6px;
}
.vb-map-box .vb-map-desc {
  font-size: 12.5px;
  color: var(--ink-muted);
  line-height: 1.7;
}
.vb-map-arrow {
  color: var(--gold);
  font-size: 15px;
  padding: 8px 0;
  text-align: center;
}
.vb-map-arrow small {
  display: block;
  color: var(--ink-muted);
  font-size: 11px;
  letter-spacing: 0.04em;
}

/* ---- Part header ---- */
.vb-part {
  margin: clamp(56px, 8vw, 90px) 0 clamp(28px, 4vw, 40px);
  padding-top: clamp(28px, 4vw, 40px);
  border-top: 2px solid var(--navy-deep);
}
.vb-part-num {
  font-family: var(--font-display-en);
  font-size: 13px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold-dim);
  font-weight: 700;
}
.vb-part-label {
  font-family: var(--font-display-jp);
  font-size: clamp(22px, 3.2vw, 32px);
  font-weight: 700;
  color: var(--navy-deep);
  letter-spacing: 0.03em;
  line-height: 1.4;
  margin: 6px 0 12px;
}
.vb-part-intro {
  font-size: 13.5px;
  line-height: 1.85;
  color: var(--ink-muted);
  border-left: 2px solid var(--line);
  padding-left: 16px;
}

/* ---- Section ---- */
.vb-sec { margin: clamp(34px, 5vw, 52px) 0; }
.vb-h2 {
  font-family: var(--font-display-jp);
  font-size: clamp(18px, 2.3vw, 23px);
  font-weight: 700;
  color: var(--navy-deep);
  letter-spacing: 0.02em;
  line-height: 1.5;
  margin-bottom: 16px;
  padding-left: 14px;
  border-left: 4px solid var(--gold);
}
.vb-h3 {
  font-family: var(--font-display-jp);
  font-size: clamp(15px, 1.8vw, 17px);
  font-weight: 700;
  color: var(--navy-deep);
  margin: 26px 0 12px;
}
.vb-p {
  font-size: clamp(14.5px, 1.5vw, 16px);
  line-height: 1.95;
  color: var(--ink-soft);
  margin-bottom: 1.3em;
}
.vb-p strong { color: var(--navy-deep); font-weight: 700; }
.vb-p em, .vb-li em { color: var(--ink); font-style: italic; }

.vb-ul, .vb-ol {
  margin: 0 0 1.4em;
  padding-left: 1.4em;
}
.vb-li {
  font-size: clamp(14px, 1.5vw, 15.5px);
  line-height: 1.9;
  color: var(--ink-soft);
  margin-bottom: 0.6em;
}
.vb-li strong { color: var(--navy-deep); }

/* ---- Definition / conclusion box ---- */
.vb-def {
  background: linear-gradient(135deg, var(--navy-deep), var(--navy-darker));
  color: #fff;
  border-radius: 12px;
  padding: clamp(22px, 3vw, 30px) clamp(24px, 3.5vw, 34px);
  margin: 26px 0;
  position: relative;
  overflow: hidden;
}
.vb-def::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(to right, transparent, var(--gold), transparent);
}
.vb-def .vb-def-tag {
  font-family: var(--font-display-en);
  font-size: 10.5px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--gold-bright);
  font-weight: 700;
  margin-bottom: 10px;
}
.vb-def p {
  font-size: clamp(15px, 1.7vw, 17.5px);
  line-height: 1.9;
  color: #fff;
  margin: 0;
  font-family: var(--font-display-jp);
  font-weight: 500;
}
.vb-def strong { color: var(--gold-bright); }

/* ---- Pull quote ---- */
.vb-quote {
  border-left: 3px solid var(--gold);
  padding: 4px 0 4px 20px;
  margin: 22px 0;
  font-size: clamp(15px, 1.6vw, 17px);
  line-height: 1.85;
  color: var(--navy-deep);
  font-family: var(--font-display-jp);
  font-weight: 600;
}
.vb-quote strong { color: var(--gold-dim); }

/* ---- Warning / caveat box ---- */
.vb-warn {
  background: #FBF3E3;
  border: 1px solid #ecd9ad;
  border-radius: 8px;
  padding: 16px 20px;
  margin: 22px 0;
  font-size: 13.5px;
  line-height: 1.85;
  color: #6b5a30;
}
.vb-warn strong { color: #8a6d28; }
.vb-warn .vb-warn-mark { font-weight: 700; margin-right: 4px; }

/* ---- Table ---- */
.vb-table-wrap { overflow-x: auto; margin: 22px 0; }
.vb-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
  min-width: 460px;
}
.vb-table th, .vb-table td {
  text-align: left;
  vertical-align: top;
  padding: 11px 14px;
  border-bottom: 1px solid var(--line);
  line-height: 1.7;
  color: var(--ink-soft);
}
.vb-table th {
  font-family: var(--font-display-jp);
  font-weight: 700;
  color: var(--navy-deep);
  background: var(--bg-subtle);
  border-bottom: 2px solid var(--gold-soft, var(--gold));
}
.vb-table td strong { color: var(--navy-deep); }
.vb-table tr:last-child td { border-bottom: none; }

/* ---- Monospace diagram ---- */
.vb-diagram {
  background: var(--navy-darker, #142844);
  color: #cdd8e6;
  border-radius: 10px;
  padding: 20px 22px;
  margin: 22px 0;
  font-family: ui-monospace, 'SF Mono', 'Cascadia Mono', monospace;
  font-size: 12.5px;
  line-height: 1.75;
  white-space: pre;
  overflow-x: auto;
}
.vb-diagram .hl { color: var(--gold-bright); }

/* ---- Appendix ---- */
.vb-appendix {
  margin-top: clamp(48px, 7vw, 80px);
  padding-top: clamp(28px, 4vw, 40px);
  border-top: 2px solid var(--navy-deep);
}
.vb-appendix .vb-h2 { border-left-color: var(--navy-deep); }

.vb-divider {
  border: none;
  border-top: 1px solid var(--line);
  margin: clamp(30px, 4vw, 44px) 0;
}
