/*
Theme Name: PT Shoes LAB
Theme URI: https://pt-shoes-lab.com/
Author: Takumi Shibata
Author URI: https://pt-shoes-lab.com/
Description: 理学療法士10年の運営者が書く 足×靴の読み物メディア「PT Shoes LAB（靴とリハビリ）」専用テーマ。lopylog 風 白基調 × ティール × 明朝見出し。zoroya-hp-builder v2.4 互換の自作テーマ。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 8.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: pt-shoes-lab
Tags: blog, two-columns, custom-menu, featured-images, full-width-template, theme-options
*/

/* 下記の本体スタイルは assets/css/_shared.css と同一内容。
   WordPress では style.css がテーマのメインスタイルシートとして読み込まれる。 */
/* ============================================================
   PT Shoes LAB v2 — Shared Design System
   A親しみ（白基調）× D規律 ハイブリッド / lopylog踏襲ミニマル
   ============================================================ */

:root {
  --c-bg: #FFFFFF;
  --c-bg-lifted: #FAFAFA;
  --c-bg-soft-accent: #E8F3F1;
  --c-text-strong: #1A1A1A;
  --c-text: #333333;
  --c-text-muted: #888888;
  --c-hairline: #EEEEEE;
  --c-accent: #0E5C57;
  --c-accent-hover: #0a4742;
  --c-note: #C0392B;

  --ff-heading: "Shippori Mincho B1", "Zen Old Mincho", "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  --ff-heading-gothic: "Zen Kaku Gothic New", -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  --ff-body: system-ui, -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", "Yu Gothic", "Zen Kaku Gothic New", sans-serif;
  --ff-mono: "Space Grotesk", ui-monospace, "SF Mono", Menlo, monospace;

  --fs-h1: clamp(28px, 5vw, 56px);
  --fs-h2: clamp(22px, 3vw, 28px);
  --fs-h3: clamp(18px, 2vw, 20px);
  --fs-body: 16px;
  --fs-small: 14px;
  --fs-eyebrow: 11px;

  --lh-body: 1.8;
  --lh-heading: 1.3;

  --maxw: 1080px;
  --maxw-narrow: 720px;
  --gap-xs: 8px;
  --gap-sm: 14px;
  --gap-md: 24px;
  --gap-lg: 48px;
  --gap-xl: 96px;

  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--c-bg);
  color: var(--c-text);
  font-family: var(--ff-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  /* 日本語の禁則処理（v2.1）：文節区切りで自然改行・約物の浮き上がり・約物のぶら下げ */
  word-break: keep-all;
  overflow-wrap: anywhere;
  line-break: strict;
  hanging-punctuation: allow-end;
}
/* 改行を起こしたくない語句に当てるユーティリティ */
.nowrap { white-space: nowrap; word-break: keep-all; }
/* 表組み・FAQ 本文・チップなど、長い和文が含まれる箇所で文節改行を強制 */
h1, h2, h3, h4, p, li, td, th, summary,
.hero__main, .hero__sub, .cat__chip-label, .cat__chip-desc, .pickup__title, .pickup__excerpt,
.np__pull, .np__stats li, .lead p, .page-content p, .page-content li, .pt-byline__meta,
.site-footer__nap, .cta-band h2 {
  word-break: keep-all;
  overflow-wrap: anywhere;
  line-break: strict;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--c-text-strong); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--c-accent); }
h1, h2, h3, h4 { font-family: var(--ff-heading); color: var(--c-text-strong); line-height: 1.5; margin: 0 0 .6em; letter-spacing: 0.02em; }
h1 { font-size: var(--fs-h1); font-weight: 700; letter-spacing: 0.01em; }
h2 { font-size: var(--fs-h2); font-weight: 700; }
h3 { font-size: var(--fs-h3); font-weight: 500; }
p { margin: 0 0 1em; }
hr { border: 0; border-top: 1px solid var(--c-hairline); margin: var(--gap-md) 0; }
button { font-family: inherit; cursor: pointer; }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gap-md); }
.container-narrow { max-width: var(--maxw-narrow); margin: 0 auto; padding: 0 var(--gap-md); }
.section { padding: var(--gap-xl) 0; }
.section-tight { padding: var(--gap-lg) 0; }
.section-lifted { background: var(--c-bg-lifted); }
.eyebrow {
  font-family: var(--ff-mono);
  font-size: var(--fs-eyebrow);
  font-weight: 500;
  letter-spacing: 0.4em;
  color: var(--c-text-muted);
  text-transform: uppercase;
  margin: 0 0 var(--gap-sm) 0;
  display: block;
}
.section-number {
  font-family: var(--ff-mono);
  font-size: var(--fs-eyebrow);
  font-weight: 500;
  letter-spacing: 0.2em;
  color: var(--c-text-muted);
  display: inline-block;
  margin-bottom: var(--gap-sm);
}
/* v2.1: 大型装飾ナンバリング（SWELL風） */
.section-ornament {
  display: flex; align-items: baseline; gap: 14px;
  margin-bottom: var(--gap-md);
  justify-content: center;
}
.section-ornament__num {
  font-family: var(--ff-mono); font-weight: 700;
  font-size: clamp(36px, 5vw, 56px);
  color: var(--c-accent); line-height: 1;
  letter-spacing: -0.02em;
}
.section-ornament__label {
  font-family: var(--ff-mono); font-weight: 500;
  font-size: 12px; letter-spacing: 0.3em;
  color: var(--c-text-muted); text-transform: uppercase;
  padding-left: 14px; border-left: 1px solid var(--c-hairline);
}
.section-ornament__rule {
  flex: 1; height: 1px; background: var(--c-hairline);
  max-width: 80px;
}
/* v2.1: 吹き出し（SWELL c-balloon 風） */
.balloon {
  position: relative;
  background: var(--c-bg-soft-accent);
  border: 1px solid color-mix(in srgb, var(--c-accent) 20%, var(--c-hairline));
  border-radius: var(--radius-md);
  padding: 18px 22px;
  margin: var(--gap-md) 0;
  font-size: 15px; line-height: 1.85;
  color: var(--c-text-strong);
}
.balloon::before {
  content: "";
  position: absolute; top: -9px; left: 36px;
  width: 16px; height: 16px;
  background: var(--c-bg-soft-accent);
  border-top: 1px solid color-mix(in srgb, var(--c-accent) 20%, var(--c-hairline));
  border-left: 1px solid color-mix(in srgb, var(--c-accent) 20%, var(--c-hairline));
  transform: rotate(45deg);
}
.balloon__author {
  display: inline-block;
  font-family: var(--ff-mono); font-size: 11px;
  letter-spacing: 0.2em; color: var(--c-accent);
  margin-bottom: 8px; text-transform: uppercase;
}
/* v2.1: 飾り罫（hairline rule with ornament） */
.ornament-rule {
  display: flex; align-items: center; gap: 14px;
  margin: var(--gap-lg) 0;
  color: var(--c-text-muted);
  font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.3em;
}
.ornament-rule::before,
.ornament-rule::after {
  content: ""; flex: 1; height: 1px;
  background: var(--c-hairline);
}
.ornament-rule__dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--c-accent);
}
.hairline-rule { height: 1px; background: var(--c-hairline); border: 0; margin: 0; }

.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--c-hairline);
}
.site-header__inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 14px var(--gap-md);
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: var(--gap-md);
}
.site-header__brand {
  grid-column: 2;
  text-align: center;
  font-family: var(--ff-mono);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0.22em;
  color: var(--c-text-strong);
}
.site-header__nav {
  grid-column: 3;
  display: flex; justify-content: flex-end; gap: var(--gap-md);
  font-size: var(--fs-small);
}
.site-header__nav a { color: var(--c-text); }
.site-header__nav a:hover { color: var(--c-accent); }

.hero {
  position: relative;
  padding: var(--gap-xl) 0 var(--gap-lg);
  text-align: center;
  background: var(--c-bg);
  overflow: hidden;
}
.hero__inner {
  max-width: var(--maxw-narrow); margin: 0 auto; padding: 0 var(--gap-md);
  display: flex; flex-direction: column; align-items: center;
}
.hero__eyebrow {
  font-family: var(--ff-mono);
  font-size: 12px; font-weight: 500;
  letter-spacing: 0.4em; color: var(--c-text-muted);
  margin: 0 0 var(--gap-md) 0;
}
.hero__main {
  font-family: var(--ff-heading); font-weight: 700;
  font-size: clamp(42px, 8vw, 96px);
  line-height: 1.1; letter-spacing: 0.04em;
  margin: 0 0 var(--gap-md) 0;
  background: linear-gradient(115deg,
    var(--c-text-strong) 0%, var(--c-text-strong) 38%,
    var(--c-accent) 38%, var(--c-accent) 62%,
    var(--c-text-strong) 62%, var(--c-text-strong) 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent; -webkit-text-fill-color: transparent;
  opacity: 0;
  animation: hero-main-in 1.2s cubic-bezier(.4,0,.2,1) .3s forwards;
}
.hero__motif {
  margin: var(--gap-sm) 0 var(--gap-md);
  width: min(420px, 88vw);
}
.hero__motif svg { width: 100%; height: auto; display: block; }
/* v2.3: 実写ヒーロー画像 */
.hero__visual {
  margin: var(--gap-md) 0 var(--gap-lg);
  width: min(880px, 92vw);
  position: relative;
  opacity: 0;
  animation: hero-photo-in 1.0s ease-out .8s forwards;
}
.hero__photo {
  width: 100%; height: auto;
  display: block;
  aspect-ratio: 16/9;
  object-fit: cover;
  border-radius: var(--radius-lg);
  box-shadow: 0 30px 60px -28px rgba(14,92,87,.28), 0 12px 30px -16px rgba(0,0,0,.15);
  background: var(--c-bg-lifted);
}
@keyframes hero-photo-in { from { opacity: 0; transform: translateY(20px) scale(.98); } to { opacity: 1; transform: translateY(0) scale(1); } }
/* hero motif の旧スタイル（互換用・新SVGはインラインで指定） */
.hero__motif .shoe { stroke: var(--c-text-strong); stroke-width: 2.2; fill: none; stroke-linecap: round; stroke-linejoin: round; }
.hero__motif .arch { stroke: var(--c-accent); stroke-width: 1.6; fill: none; stroke-linecap: round; }
.hero__motif .marker { fill: var(--c-accent); }
.hero__motif .shoe-detail path,
.hero__motif .shoe-detail line { stroke-linecap: round; stroke-linejoin: round; }
.hero__sub {
  font-size: 16px; color: var(--c-text); margin: 0 0 var(--gap-md);
  opacity: 0; animation: hero-fade-up .8s ease-out 1.3s forwards;
}
.hero__cta {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--c-accent); color: #fff;
  font-size: 14px; font-weight: 500;
  padding: 13px 26px;
  border-radius: var(--radius-sm);
  letter-spacing: 0.04em;
  transition: background .2s ease, transform .15s ease;
  opacity: 0; animation: hero-fade-up .8s ease-out 1.5s forwards;
}
.hero__cta:hover { background: var(--c-accent-hover); color: #fff; }
.hero__cta:active { transform: translateY(1px); }
.hero__cta::after { content: "→"; font-family: var(--ff-mono); font-weight: 500; }

@keyframes hero-main-in { from { opacity: 0; clip-path: inset(0 100% 0 0); } to { opacity: 1; clip-path: inset(0 0 0 0); } }
@keyframes hero-fade-up { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

/* hero motif アニメーション（v2.2：詳細SVG向け） */
.hero__motif .shoe-detail { opacity: 0; animation: shoe-draw 1.4s ease-out 0.9s forwards; }
.hero__motif .arch-group { opacity: 0; animation: arch-draw 1.0s ease-out 2.1s forwards; }
.hero__motif .marker { opacity: 0; animation: hero-fade-up .6s ease-out 2.6s forwards; }
.hero__motif text { opacity: 0; animation: hero-fade-up .6s ease-out 2.8s forwards; }
@keyframes shoe-draw { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
@keyframes arch-draw { from { opacity: 0; } to { opacity: 1; } }
@keyframes stroke-draw { to { stroke-dashoffset: 0; } }
@keyframes arch-fade { to { opacity: 1; } }

.lead { padding: var(--gap-lg) 0 var(--gap-xl); }
.lead__inner { max-width: var(--maxw-narrow); margin: 0 auto; padding: 0 var(--gap-md); }
.lead p {
  font-size: 17px; line-height: 2.0;
  margin: 0 0 1.4em;
  color: var(--c-text);
}
.lead p:first-of-type::first-letter {
  font-family: var(--ff-mono); font-weight: 700; font-size: 1.4em;
  color: var(--c-accent); margin-right: 2px;
}

.cat {
  background: var(--c-bg-lifted);
  padding: var(--gap-xl) 0;
}
.cat__head {
  text-align: center; margin-bottom: var(--gap-lg);
  max-width: var(--maxw-narrow); margin-left: auto; margin-right: auto;
  padding: 0 var(--gap-md);
}
.cat__head h2 { margin: 0 0 12px; }
.cat__head p { color: var(--c-text-muted); font-size: var(--fs-small); }
.cat__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--gap-sm);
  max-width: var(--maxw); margin: 0 auto;
  padding: 0 var(--gap-md);
}
.cat__chip {
  position: relative;
  display: flex; flex-direction: column;
  background: #fff;
  border: 1px solid var(--c-hairline);
  border-radius: var(--radius-md);
  padding: 0;
  text-decoration: none;
  transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
  overflow: hidden;
}
/* v2.1: チップ上端のティール帯（SWELL風アクセント） */
.cat__chip::before {
  content: "";
  position: absolute; top: 0; left: 0;
  width: 100%; height: 3px;
  background: var(--c-accent);
  transform: scaleX(0); transform-origin: left;
  transition: transform .25s ease;
}
.cat__chip:hover {
  border-color: var(--c-accent);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px -12px rgba(14,92,87,.25);
}
.cat__chip:hover::before { transform: scaleX(1); }
.cat__chip:hover .cat__chip-arrow { color: var(--c-accent); transform: translateX(3px); }
/* v2.3: カテゴリチップ実写サムネ */
.cat__chip-photo {
  position: relative;
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--c-bg-lifted);
}
.cat__chip-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}
.cat__chip:hover .cat__chip-photo img { transform: scale(1.05); }
.cat__chip-photo::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 40%;
  background: linear-gradient(180deg, transparent 0%, rgba(255,255,255,.7) 100%);
  pointer-events: none;
}
.cat__chip-body {
  display: flex; flex-direction: column; gap: 10px;
  padding: 18px 20px 18px;
}
.cat__chip-label {
  font-family: var(--ff-heading); font-weight: 700; font-size: 17px;
  color: var(--c-text-strong);
  letter-spacing: 0.02em; line-height: 1.5;
}
.cat__chip-desc { font-size: 13px; color: var(--c-text-muted); margin: 0; line-height: 1.7; }
.cat__chip-meta {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 4px; padding-top: 10px;
  border-top: 1px dashed var(--c-hairline);
  font-family: var(--ff-mono); font-size: 11px;
  color: var(--c-text-muted); letter-spacing: 0.1em;
}
.cat__chip-arrow { color: var(--c-text-muted); transition: color .2s ease, transform .2s ease; }

.pickup { padding: var(--gap-xl) 0; }
.pickup__head {
  text-align: center; margin-bottom: var(--gap-lg);
  max-width: var(--maxw-narrow); margin-left: auto; margin-right: auto;
  padding: 0 var(--gap-md);
}
.pickup__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--gap-md);
  max-width: var(--maxw); margin: 0 auto;
  padding: 0 var(--gap-md);
}
.pickup__card {
  display: flex; flex-direction: column;
  background: var(--c-bg);
  border: 1px solid var(--c-hairline);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.pickup__card:hover {
  border-color: var(--c-accent);
  transform: translateY(-3px);
  box-shadow: 0 10px 28px -16px rgba(14,92,87,.28);
}
.pickup__thumb {
  aspect-ratio: 16/9;
  background: var(--c-bg-lifted) center/cover;
  position: relative;
}
.pickup__thumb--placeholder {
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-mono); font-size: 11px;
  color: var(--c-text-muted); letter-spacing: 0.2em;
  background: repeating-linear-gradient(135deg, var(--c-bg-lifted) 0 12px, #f3f3f3 12px 24px);
}
/* v2.2: PICKUP の SVG アート サムネ */
.pickup__thumb--art {
  position: relative;
  background:
    radial-gradient(circle at 30% 30%, #fff 0%, var(--c-bg-lifted) 70%, #f1efe9 100%);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.pickup__thumb--art::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(0deg, rgba(14,92,87,0.04) 0%, transparent 50%),
    linear-gradient(180deg, transparent 60%, rgba(14,92,87,0.06) 100%);
  pointer-events: none;
}
.pickup__art {
  width: 100%; height: 100%;
  display: block;
  padding: 8px;
}
/* v2.3: PICKUP の実写サムネ */
.pickup__thumb--photo {
  position: relative;
  overflow: hidden;
  background: var(--c-bg-lifted);
  aspect-ratio: 16/9;
}
.pickup__thumb--photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s ease;
}
.pickup__card:hover .pickup__thumb--photo img { transform: scale(1.04); }
/* v2.1: PICKUP カードのカテゴリ帯（SWELL風） */
.pickup__cat-band {
  position: absolute; top: 12px; left: 12px;
  background: rgba(255,255,255,.95);
  backdrop-filter: blur(6px);
  padding: 5px 12px;
  font-family: var(--ff-mono); font-size: 10px;
  font-weight: 700;
  color: var(--c-accent); letter-spacing: 0.18em;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--c-accent) 25%, var(--c-hairline));
}
.pickup__body { padding: 20px 22px 22px; }
.pickup__title {
  font-family: var(--ff-heading); font-weight: 700; font-size: 17px;
  color: var(--c-text-strong); margin: 0 0 10px;
  line-height: 1.55; letter-spacing: 0.02em;
}
.pickup__excerpt {
  font-size: 13.5px; color: var(--c-text); line-height: 1.85;
  margin: 0 0 14px;
}
.pickup__meta {
  display: flex; justify-content: space-between; align-items: center;
  border-top: 1px dashed var(--c-hairline);
  padding-top: 10px;
  font-family: var(--ff-mono); font-size: 11px;
  color: var(--c-text-muted); letter-spacing: 0.1em;
}
.pickup__meta-read { color: var(--c-accent); }

.np {
  background: var(--c-bg-lifted);
  padding: var(--gap-xl) 0;
}
.np__inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 0 var(--gap-md);
  display: grid;
  grid-template-columns: minmax(0,1fr) minmax(0,1.4fr);
  gap: var(--gap-xl);
}
/* v2.2: 数字とFAQを分離したときの単列レイアウト */
.np__inner--single {
  grid-template-columns: 1fr;
  max-width: 880px;
}
.np__numbers {
  display: flex; flex-direction: column; gap: var(--gap-md);
}
.np__pull {
  font-family: var(--ff-mono); font-weight: 700;
  font-size: clamp(80px, 13vw, 144px);
  line-height: .9; letter-spacing: -0.04em;
  color: var(--c-accent); margin: 0;
  position: relative;
  display: inline-block;
}
/* v2.1: 大型数字の左右に装飾線 */
.np__pull::before,
.np__pull::after {
  content: "";
  position: absolute; top: 50%;
  width: 28px; height: 1px;
  background: var(--c-accent); opacity: 0.4;
}
.np__pull::before { right: calc(100% + 12px); }
.np__pull::after { left: calc(100% + 12px); }
.np__pull-suffix { font-size: 0.28em; color: var(--c-text-strong); letter-spacing: 0.08em; margin-left: 10px; vertical-align: 18%; font-weight: 500; }
.np__stats { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.np__stats li {
  font-size: 14px; color: var(--c-text);
  border-top: 1px solid var(--c-hairline); padding-top: 8px;
}
.np__stats strong { color: var(--c-text-strong); font-weight: 500; margin-right: 6px; }
/* 旧 .np__faq 系のクラスは v2.2 で .faq__list へ移管・廃止（死コード削除） */

/* v2.2: FAQ を独立セクション化（一言要点＋記事誘導） */
.faq {
  padding: var(--gap-xl) 0;
  background: var(--c-bg);
  border-top: 1px solid var(--c-hairline);
}
.faq__inner {
  max-width: 880px; margin: 0 auto;
  padding: 0 var(--gap-md);
  display: flex; flex-direction: column; gap: var(--gap-md);
}
.faq__lead {
  font-size: 14px; color: var(--c-text-soft, var(--c-text));
  margin: 0 0 var(--gap-sm, 12px);
  line-height: 1.7;
}
.faq__list {
  display: flex; flex-direction: column; gap: 6px;
}
.faq__list details {
  border-top: 1px solid var(--c-hairline);
  padding: 14px 0;
}
.faq__list details[open] { padding-bottom: 18px; }
.faq__list details:last-of-type { border-bottom: 1px solid var(--c-hairline); }
.faq__list summary {
  font-family: var(--ff-heading); font-weight: 500; font-size: 15px;
  color: var(--c-text-strong);
  cursor: pointer; list-style: none;
  display: flex; justify-content: space-between; align-items: flex-start; gap: 12px;
  line-height: 1.5;
}
.faq__list summary::-webkit-details-marker { display: none; }
.faq__list summary::after {
  content: "+"; font-family: var(--ff-mono); font-weight: 500;
  color: var(--c-accent); font-size: 18px; flex: 0 0 auto;
  transition: transform .2s ease;
}
.faq__list details[open] summary::after { content: "−"; }
.faq__list p {
  font-size: 14px; color: var(--c-text); line-height: 1.85;
  margin: 12px 0 0;
}
.faq__more {
  display: inline-block;
  margin-left: 6px;
  color: var(--c-accent);
  font-size: 13px;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color .15s ease;
}
.faq__more:hover { border-bottom-color: var(--c-accent); }

.cta-band {
  position: relative;
  text-align: center;
  padding: var(--gap-xl) var(--gap-md);
  background:
    radial-gradient(ellipse at 50% -10%, var(--c-bg-soft-accent) 0%, transparent 60%),
    linear-gradient(180deg, #fff 0%, var(--c-bg-lifted) 100%);
  border-top: 1px solid var(--c-hairline);
  overflow: hidden;
}
/* v2.1: CTAバンドの装飾モチーフ（淡いアーチ曲線が背景にうっすら） */
.cta-band::before {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 200'><path d='M0 140 Q 200 60, 400 100 Q 600 140, 800 80' stroke='%230E5C57' stroke-width='1' fill='none' opacity='0.15'/></svg>");
  background-repeat: no-repeat;
  background-position: center 70%;
  background-size: cover;
  pointer-events: none;
}
.cta-band__inner { max-width: var(--maxw-narrow); margin: 0 auto; position: relative; z-index: 1; }
.cta-band h2 {
  font-size: clamp(22px, 3vw, 32px);
  margin: 0 0 var(--gap-sm);
  line-height: 1.6;
}
.cta-band p { color: var(--c-text-muted); font-size: var(--fs-small); margin: 0 0 var(--gap-md); }
.cta-band__btn {
  position: relative;
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--c-accent); color: #fff;
  font-size: 15px; font-weight: 500;
  padding: 16px 36px;
  border-radius: var(--radius-sm);
  letter-spacing: 0.04em;
  transition: background .2s ease, transform .15s ease, box-shadow .2s ease;
  box-shadow: 0 8px 20px -8px rgba(14,92,87,.45);
  overflow: hidden;
}
/* v2.1: シャイニーCTAの光沢オーバーレイ */
.cta-band__btn::before {
  content: "";
  position: absolute; top: 0; left: -120%;
  width: 60%; height: 100%;
  background: linear-gradient(110deg, transparent 40%, rgba(255,255,255,.35) 50%, transparent 60%);
  transition: left .8s ease;
}
.cta-band__btn:hover { background: var(--c-accent-hover); color: #fff; transform: translateY(-1px); box-shadow: 0 12px 28px -8px rgba(14,92,87,.55); }
.cta-band__btn:hover::before { left: 130%; }
.cta-band__btn::after { content: "→"; font-family: var(--ff-mono); position: relative; z-index: 1; }

.site-footer {
  border-top: 1px solid var(--c-hairline);
  background: var(--c-bg);
  padding: var(--gap-lg) 0 var(--gap-md);
}
.site-footer__inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 0 var(--gap-md);
  display: grid;
  grid-template-columns: minmax(0,1.2fr) minmax(0,1fr) minmax(0,1fr);
  gap: var(--gap-lg);
}
.site-footer__byline {
  display: flex; gap: 14px; align-items: flex-start;
}
.site-footer__avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--c-bg-lifted) center/cover;
  flex: 0 0 auto;
  border: 1px solid var(--c-hairline);
}
.site-footer__byline-meta { font-size: 13px; color: var(--c-text); line-height: 1.6; }
.site-footer__byline-name { font-weight: 500; color: var(--c-text-strong); margin: 0; }
.site-footer__byline-role { color: var(--c-text-muted); margin: 0; font-size: 12px; }
.site-footer__byline-link {
  font-family: var(--ff-mono); font-size: 11px;
  color: var(--c-accent); letter-spacing: 0.1em; text-transform: uppercase;
  margin-top: 4px; display: inline-block;
}
.site-footer h4 {
  font-family: var(--ff-mono); font-weight: 500;
  font-size: 11px; letter-spacing: 0.2em;
  color: var(--c-text-muted); text-transform: uppercase;
  margin: 0 0 12px;
}
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer li { font-size: 13px; margin-bottom: 6px; }
.site-footer__nap { font-size: 12px; color: var(--c-text-muted); line-height: 1.7; margin: 0; }
.site-footer__nap strong { color: var(--c-text); font-weight: 500; }
.site-footer__bottom {
  margin-top: var(--gap-lg);
  border-top: 1px solid var(--c-hairline);
  padding-top: 14px;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px;
  font-size: 11px; color: var(--c-text-muted);
  max-width: var(--maxw); margin-left: auto; margin-right: auto;
  padding-left: var(--gap-md); padding-right: var(--gap-md);
  font-family: var(--ff-mono); letter-spacing: 0.1em;
}

.pt-byline {
  display: flex; gap: 14px; align-items: center;
  border-top: 1px solid var(--c-hairline);
  padding: var(--gap-md) 0;
  margin-top: var(--gap-lg);
  font-size: 13px;
}
.pt-byline__avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--c-bg-lifted) center/cover;
  border: 1px solid var(--c-hairline);
  flex: 0 0 auto;
}
.pt-byline__meta { color: var(--c-text); }
.pt-byline__meta strong { color: var(--c-text-strong); font-weight: 500; }
.pt-byline__meta .sep { color: var(--c-text-muted); margin: 0 8px; }
.pt-byline__meta a { color: var(--c-accent); }

.page-hero {
  padding: var(--gap-xl) 0 var(--gap-lg);
  text-align: center;
  border-bottom: 1px solid var(--c-hairline);
}
.page-hero h1 { font-size: clamp(28px, 4vw, 40px); margin: 0 0 var(--gap-sm); }
.page-hero p { color: var(--c-text-muted); font-size: var(--fs-small); }

.page-content { padding: var(--gap-lg) 0 var(--gap-xl); }
.page-content__inner { max-width: var(--maxw-narrow); margin: 0 auto; padding: 0 var(--gap-md); }
.page-content h2 {
  margin-top: var(--gap-lg);
  padding-bottom: 8px;
  border-bottom: 1px solid var(--c-hairline);
}
.page-content h3 { margin-top: var(--gap-md); }
.page-content table {
  width: 100%; border-collapse: collapse;
  margin: var(--gap-md) 0;
  font-size: 14px;
}
.page-content table th,
.page-content table td {
  text-align: left; padding: 12px 10px;
  border-bottom: 1px solid var(--c-hairline);
  vertical-align: top;
}
.page-content table th {
  font-family: var(--ff-heading); font-weight: 500;
  background: var(--c-bg-lifted);
  font-size: 13px;
}

.form-iframe-wrap { padding: var(--gap-md) 0; }
.form-iframe-wrap iframe { width: 100%; border: 1px solid var(--c-hairline); border-radius: var(--radius-md); min-height: 520px; }

@media (max-width: 1024px) {
  .np__inner { grid-template-columns: 1fr; gap: var(--gap-lg); }
  .site-footer__inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  :root { --gap-xl: 56px; --gap-lg: 36px; }
  .site-header__inner { grid-template-columns: 1fr 1fr; padding: 12px var(--gap-md); }
  .site-header__brand { grid-column: 1; text-align: left; font-size: 14px; letter-spacing: 0.18em; }
  .site-header__nav { grid-column: 2; gap: var(--gap-sm); font-size: 13px; }
  .hero { padding: var(--gap-lg) 0 var(--gap-md); }
  .hero__main { font-size: clamp(36px, 10vw, 56px); }
  .hero__motif { width: 88vw; }
  .lead p { font-size: 16px; line-height: 1.9; }
  .site-footer__inner { grid-template-columns: 1fr; gap: var(--gap-md); }
  .site-footer__bottom { flex-direction: column; gap: 6px; }
  .pickup__grid { grid-template-columns: 1fr; }
}

.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
:focus-visible { outline: 2px solid var(--c-accent); outline-offset: 2px; border-radius: 2px; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
  .hero__main, .hero__sub, .hero__cta { opacity: 1; animation: none; clip-path: none; }
  .hero__motif .shoe { stroke-dashoffset: 0; }
  .hero__motif .arch, .hero__motif .marker { opacity: 1; }
}

/* zoroya-build: v2 / fv: fv-AC-hybrid-shoe-arch / palette: white+teal */
