/* =========================================================
   Healing Solutions — Strength / Capability LP pages
   Loaded in addition to style.css + works.css.
   Each page sets its accent via <body style="--accent:#..; --accent-dark:#..">
   ========================================================= */

/* ---------- Hero key points (under tagline) ---------- */
.cap-points { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 36px; max-width: 780px; }
.cap-point { background: rgba(255,255,255,.66); border: 1px solid var(--line); border-radius: 14px; padding: 18px 20px; backdrop-filter: blur(4px); }
.cap-point strong { display: block; font-family: var(--head); font-weight: 900; font-size: clamp(19px, 2.1vw, 26px); color: var(--accent-dark); line-height: 1.25; word-break: keep-all; }
.cap-point span { display: block; font-size: 12.5px; color: var(--muted); margin-top: 7px; line-height: 1.6; }

/* ---------- Section intro lead (left aligned variant already via section__title) ---------- */
.cap-section-lead { max-width: 760px; margin: 0 auto clamp(36px,5vw,52px); text-align: center; color: var(--muted); font-size: clamp(15px,1.3vw,17px); line-height: 2; }

/* ---------- Pain points (こんなお悩み) ---------- */
.cap-pains { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; max-width: 940px; margin: 0 auto; }
.cap-pain { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 24px 26px; display: flex; gap: 15px; align-items: flex-start; box-shadow: var(--shadow-sm); }
.cap-pain::before { content: "?"; flex: none; width: 32px; height: 32px; border-radius: 50%; display: grid; place-items: center; background: color-mix(in srgb, var(--accent) 14%, #fff); color: var(--accent-dark); font-family: var(--serif); font-style: italic; font-weight: 700; font-size: 18px; }
.cap-pain p { font-size: 15px; line-height: 1.85; color: #3c4d42; margin: 0; }

/* ---------- Approach: numbered rich rows ---------- */
.cap-rows { display: grid; gap: clamp(18px, 2.5vw, 26px); }
.cap-row { display: grid; grid-template-columns: 70px 1fr; gap: 24px; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: clamp(24px, 3vw, 36px); align-items: start; transition: transform .4s var(--ease), box-shadow .4s; }
.cap-row:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.cap-row__no { font-family: var(--serif); font-style: italic; font-size: 38px; color: var(--accent); line-height: 1; }
.cap-row h3 { font-size: clamp(19px, 2.1vw, 24px); line-height: 1.4; margin: 2px 0 12px; }
.cap-row p { color: #3c4d42; line-height: 1.95; font-size: 15px; margin: 0; }
.cap-row p + p { margin-top: 12px; }

/* ---------- Scope tags ---------- */
.cap-scope { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; max-width: 900px; margin: 0 auto; }
.cap-scope li { font-family: var(--head); font-weight: 700; font-size: 14px; color: var(--accent-dark); background: color-mix(in srgb, var(--accent) 9%, #fff); border: 1px solid color-mix(in srgb, var(--accent) 22%, #fff); padding: 12px 22px; border-radius: 999px; }

/* ---------- Process steps ---------- */
.cap-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.cap-step { position: relative; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 30px 24px; }
.cap-step__no { width: 40px; height: 40px; border-radius: 50%; background: var(--accent); color: #fff; display: grid; place-items: center; font-family: var(--head); font-weight: 900; font-size: 17px; margin-bottom: 16px; }
.cap-step h3 { font-size: 16px; line-height: 1.4; margin: 0 0 9px; }
.cap-step p { font-size: 13px; color: #46574c; line-height: 1.85; margin: 0; }

/* ---------- Related products note ---------- */
.cap-products-note { text-align: center; color: var(--muted); font-size: 13.5px; margin-top: 26px; }
.cap-products-note a { color: var(--accent-dark); font-weight: 700; }

/* ---------- Big quote / statement band ---------- */
.cap-statement { text-align: center; max-width: 860px; margin: 0 auto; }
.cap-statement p { font-family: var(--head); font-weight: 700; font-size: clamp(20px, 2.6vw, 30px); line-height: 1.7; color: var(--ink); }
.cap-statement strong { color: var(--accent-dark); }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .cap-pains { grid-template-columns: 1fr; }
  .cap-steps { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .cap-points { grid-template-columns: 1fr; }
  .cap-steps { grid-template-columns: 1fr; }
  .cap-row { grid-template-columns: 1fr; gap: 8px; }
}

/* ---------- Flat key visual (no hero overlap) for capability pages ---------- */
.wd-visual--flat { padding-top: clamp(16px, 2.5vw, 36px); }
.wd-visual--flat .container { margin-top: 0; }

/* ---------- 2-column capability hero (text + image) ---------- */
.cap-hero { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(290px, 0.82fr); gap: clamp(28px, 4vw, 56px); align-items: center; margin: clamp(16px, 2.4vw, 26px) 0 clamp(30px, 4vw, 42px); }
.cap-hero__main { min-width: 0; }
.cap-hero__main h1 { font-size: clamp(30px, 4.2vw, 50px); }
.cap-hero__main .wd-tagline { margin-bottom: 28px; }
.cap-hero__media { margin: 0; border-radius: var(--radius-l); overflow: hidden; border: 6px solid #fff; box-shadow: var(--shadow-lg); background: var(--mint-2); }
.cap-hero__media img { display: block; width: 100%; aspect-ratio: 4 / 3.3; object-fit: cover; }
@media (max-width: 900px) {
  .cap-hero { grid-template-columns: 1fr; gap: 22px; margin-bottom: 26px; }
  .cap-hero__media { max-width: 600px; }
  .cap-hero__media img { aspect-ratio: 16 / 10; }
}
