/*
Theme Name: White Berry
Theme URI: https://www.whiteberry-niigata.com/
Author: Mia
Description: White Berry こうなん歯科・万代デンタルクリニック 公式サイトテーマ。エンジ×ミルキーベージュ×チャコール。医療広告ガイドライン準拠設計(費用・リスクの一元管理ショートコード内蔵)。
Version: 1.2.1
Requires PHP: 8.0
Text Domain: whiteberry
*/

/* ============ Design tokens ============ */
:root {
	--wb-accent:     #7A2638;
	--wb-accent-dk:  #6E1F31;
	--wb-bg:         #EDEEF0;
	--wb-bg-light:   #FFFFFF;
	--wb-text:       #2E2E2C;
	--wb-line:       #D3D4D6;
	--wb-serif: 'Noto Serif JP', serif;
	--wb-display: 'Cormorant Garamond', 'Noto Serif JP', serif;
	--wb-sans:  'Noto Sans JP', sans-serif;
	--wb-maxw: 1240px;
	--wb-radius: 2px;
}

/* ============ Base ============ */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*, *::before, *::after { animation: none !important; transition: none !important; }
}
body {
	margin: 0;
	background: var(--wb-bg-light);
	color: var(--wb-text);
	font-family: var(--wb-sans);
	font-size: 16px;
	line-height: 1.9;
	-webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--wb-accent); text-underline-offset: 0.2em; }
a:focus-visible { outline: 2px solid var(--wb-accent); outline-offset: 2px; }

h1, h2, h3 {
	font-family: var(--wb-serif);
	font-weight: 400;
	line-height: 1.5;
	letter-spacing: 0.04em;
	color: var(--wb-text);
}
h2 { font-size: clamp(1.5rem, 2.6vw, 2rem); margin: 3.5rem 0 1.25rem; }
h3 { font-size: 1.25rem; margin: 2.5rem 0 1rem; }
@media (max-width: 600px) {
	h2 { font-size: 1.4rem; }
}

.wb-container { max-width: var(--wb-maxw); margin: 0 auto; padding: 0 1.25rem; }

/* ============ Header ============ */
.wb-header {
	background: transparent;
	border-bottom: none;
	position: absolute;
	top: 0; left: 0; right: 0;
	z-index: 30;
}


/* ヘッダー:スティッキー(スクロール後に上から降りてくる) */
.wb-header.is-sticky {
	position: fixed;
	top: 0; left: 0; right: 0;
	background: rgba(255,255,255,0.82);
	backdrop-filter: blur(20px) saturate(1.2);
	-webkit-backdrop-filter: blur(20px) saturate(1.2);
	border-bottom: 1px solid var(--wb-line);
	box-shadow: 0 1px 8px rgba(0,0,0,0.04);
	animation: wb-slideDown 0.35s ease;
}
@keyframes wb-slideDown {
	from { transform: translateY(-100%); opacity: 0; }
	to   { transform: translateY(0); opacity: 1; }
}
/* トップ以外のページ・FV画像がない時は通常の白ヘッダーに戻す */
body:not(.home) .wb-header,
.wb-header.is-solid {
	position: static;
	background: var(--wb-bg-light);
	border-bottom: 1px solid var(--wb-line);
}
.wb-header__inner {
	max-width: 1240px; margin: 0 auto; padding: 1rem 1.25rem 0.8rem;
	display: flex;
	align-items: center;
	gap: 1.2rem;
	flex-wrap: wrap;
}
.wb-header__logo, .wb-header__logo--img { margin-right: auto; }
.wb-header .wb-nav--pc { order: 0; }
.wb-header .wb-menu-btn { order: 1; }
.wb-header .wb-cta { order: 2; margin: 0; }
.wb-header__logo {
	color: var(--wb-text); text-decoration: none;
	display: flex; align-items: center;
}
.wb-header__logo-img {
	height: 40px;
	width: auto;
}
.wb-header__logo-text {
	font-family: var(--wb-sans);
	font-size: 0.93rem;
	font-weight: 400;
	letter-spacing: 0.14em;
	color: #58585c;
	margin-left: 0.6rem;
}
/* ハンバーガーはheader__innerの右端 */
.wb-header__inner > .wb-topnav__toggle { margin-left: auto; }
.wb-nav ul { list-style: none; display: flex; gap: 1.3rem; margin: 0; padding: 0.2rem 0 0; flex-wrap: wrap; align-items: center; }
.wb-nav a { color: var(--wb-text); text-decoration: none; font-size: 0.88rem; white-space: nowrap; }
/* ドロップダウン(サブメニュー) */
.wb-nav li { position: relative; }
.wb-nav li.menu-item-has-children > a::after { content: " ▾"; font-size: 0.7em; color: var(--wb-accent); }
.wb-nav ul.sub-menu { display: none; position: absolute; top: 100%; left: -0.8rem; z-index: 50;
	flex-direction: column; gap: 0; min-width: 13rem; padding: 0.4rem 0;
	background: #fff; border: 1px solid var(--wb-line, #D3D4D6); box-shadow: 0 6px 18px rgba(46,46,44,0.08); }
.wb-nav li:hover > ul.sub-menu,
.wb-nav li:focus-within > ul.sub-menu { display: flex; }
.wb-nav ul.sub-menu li { width: 100%; }
.wb-nav ul.sub-menu a { display: block; padding: 0.55rem 1rem; font-size: 0.85rem; }
.wb-nav ul.sub-menu a:hover { background: var(--wb-bg, #D3D4D6); }
/* ホバーの隙間でメニューが閉じないように */
.wb-nav li.menu-item-has-children > a { padding-bottom: 0.6rem; margin-bottom: -0.6rem; }
/* ヘッダー内CTAはコンパクトに */
.wb-header .wb-btn { padding: 0.5em 1.3em; font-size: 0.82rem; white-space: nowrap; }

@media (max-width: 1200px) {
	.wb-nav ul.sub-menu { position: absolute; } /* PCドロップダウン維持 */
}
@media (max-width: 700px) {
	.wb-header__inner { grid-template-columns: 1fr auto; grid-template-areas: "logo cta" "nav nav"; }
	.wb-nav ul.sub-menu { position: static; display: none; border: none; box-shadow: none; background: transparent; padding-left: 1rem; }
	.wb-nav li:hover > ul.sub-menu, .wb-nav li:focus-within > ul.sub-menu { display: flex; }
}
.wb-nav a:hover { color: var(--wb-accent); }

/* ============ Buttons / CTA ============ */
.wb-btn {
	display: inline-block;
	background: var(--wb-accent);
	color: #fff;
	font-size: 0.95rem;
	letter-spacing: 0.08em;
	text-decoration: none;
	padding: 0.85em 2.2em;
	border-radius: var(--wb-radius);
	transition: background 0.2s ease;
}
.wb-btn:hover { background: var(--wb-accent-dk); }
.wb-btn:focus-visible { outline: 2px solid var(--wb-text); outline-offset: 2px; }
.wb-cta { text-align: center; margin: 2.5rem 0; }
.wb-textlink {
	display: inline-block;
	margin-top: 2rem;
	font-size: 0.95rem;
	letter-spacing: 0.08em;
	color: var(--wb-accent);
	text-decoration: none;
	border-bottom: 1px solid var(--wb-accent);
	padding-bottom: 0.2em;
	transition: color 0.2s, border-color 0.2s;
}
.wb-textlink--inline {
	color: var(--wb-accent);
	text-decoration: underline;
	transition: color 0.2s;
}
.wb-textlink--inline:hover { color: var(--wb-accent); }
.wb-textlink:hover { color: var(--wb-accent-dk); border-color: var(--wb-accent-dk); }
.wb-contact-note { font-size: 0.92rem; text-align: center; }

/* ============ Hero (FVコピー確定版) ============ */
.wb-hero {
	background: #fff;
	padding: clamp(3rem, 8vw, 6.5rem) 0;
}
.wb-header__logo--img img { max-height: 42px; width: auto; }
.wb-header__logo--img small { display: block; font-size: 0.62rem; color: var(--wb-accent); letter-spacing: 0.04em; margin-top: 0.05em; }
.wb-hero__catch {
	font-family: var(--wb-serif);
	font-weight: 600;
	font-size: clamp(1.5rem, 3.4vw, 2.4rem);
	line-height: 1.8;
	letter-spacing: 0.06em;
	margin: 0 0 1.8rem;
}
.wb-hero__catch .accent { color: var(--wb-accent); }
.wb-hero__band {
	font-size: 0.85rem; letter-spacing: 0.14em; color: var(--wb-text);
	border-top: 1px solid var(--wb-line);
	padding-top: 1rem; max-width: 40em;
}

/* ============ Signature: 縦書きラベル+エンジ面 ============ */
/* セクション左肩の縦書きラベル(モックの「お知らせ」帯の継承) */
.wb-section { padding: clamp(3.5rem, 7vw, 6rem) 0; }
.wb-section--alt { background: #F1F2F3; }

/* ── スクロール表示アニメーション(.wb-reveal) ── */
.wb-reveal {
	opacity: 0;
	transform: translateY(30px);
	transition:
		opacity 1s cubic-bezier(0.25, 0.1, 0.25, 1) var(--wb-d, 0s),
		transform 1s cubic-bezier(0.25, 0.1, 0.25, 1) var(--wb-d, 0s);
}
.wb-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
	.wb-reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ── セクションヘッダー:英字ラベル+日本語見出し ── */
.wb-sh { margin-bottom: clamp(2.5rem, 4vw, 4rem); }
.wb-sh--center { text-align: center; }
.wb-sh__en {
	display: block;
	font-family: var(--wb-display);
	font-size: clamp(3.2rem, 7vw, 5.5rem);
	font-weight: 400;
	letter-spacing: 0.18em;
	line-height: 1;
	color: var(--wb-text);
	opacity: 0.2;
	margin-bottom: 0.6rem;
	text-transform: uppercase;
}
.wb-sh__ja {
	font-family: var(--wb-serif);
	font-size: clamp(1.5rem, 2.8vw, 2.2rem);
	font-weight: 400;
	letter-spacing: 0.06em;
	line-height: 1.5;
	color: var(--wb-text);
	margin: 0;
}
.wb-sh__desc {
	font-size: clamp(0.92rem, 1.3vw, 1.02rem);
	line-height: 2;
	color: #58585c;
	margin: 1.2rem 0 0;
	max-width: 36em;
}
.wb-sh--center .wb-sh__desc { margin-inline: auto; }

/* ── カードのスタガー表示(偶数を下にオフセット) ── */
@media (min-width: 821px) {
	.wb-cards--stagger .wb-card:nth-child(even) { margin-top: 2.8rem; }
}
.wb-vlabel {
	writing-mode: vertical-rl;
	font-size: 0.78rem;
	letter-spacing: 0.3em;
	color: #fff;
	background: var(--wb-accent);
	padding: 1.1em 0.55em;
	float: left;
	margin: 0 1.5rem 1rem 0;
}
@media (max-width: 600px) {
	.wb-vlabel { writing-mode: horizontal-tb; float: none; display: inline-block; padding: 0.3em 1em; margin: 0 0 1rem; }
}
/* 写真に重ねるエンジのパネル(ここぞの1〜2箇所限定で使用) */
.wb-panel-accent {
	background: var(--wb-accent);
	color: #fff;
	padding: 2rem 2.2rem;
	max-width: 26em;
}
.wb-panel-accent h2, .wb-panel-accent h3 { color: #fff; margin-top: 0; }
/* ── トップページ:カード ── */
.wb-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.4rem; margin: 2rem 0; }
.wb-cards--menu, .wb-cards--clinic { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 820px) { .wb-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .wb-cards, .wb-cards--menu, .wb-cards--clinic { grid-template-columns: 1fr; } }
@media (max-width: 480px) { .wb-cards--stagger .wb-card:nth-child(even) { margin-top: 0; } }
.wb-card {
	display: flex; flex-direction: column; gap: 0.5em;
	padding: 1.6rem 1.6rem; background: #fff;
	border: 1px solid var(--wb-line, #D3D4D6); border-radius: 2px;
	text-decoration: none; color: var(--wb-text);
	transition: border-color 0.3s, transform 0.3s, box-shadow 0.3s;
}
a.wb-card:hover { border-color: var(--wb-accent); transform: translateY(-3px); box-shadow: 0 12px 32px rgba(122,38,56,0.07); }
.wb-card__title { font-family: var(--wb-serif); font-size: 1.18rem; font-weight: 400; letter-spacing: 0.03em; }
.wb-card__sub { font-size: 0.82rem; color: #76767c; line-height: 1.6; }
.wb-card--static { gap: 0.4em; }
.wb-card--static a { font-size: 0.85rem; color: var(--wb-accent); text-decoration: none; margin-top: 0.4em; }
.wb-card--static a:hover { color: var(--wb-accent-dk); text-decoration: underline; }
/* パネル(エンジ面)を1箇所だけ使う */
.wb-panel-accent .wb-textlink--on-accent { color: #fff; border-color: rgba(255,255,255,0.5); }
.wb-panel-accent .wb-textlink--on-accent:hover { color: #fff; border-color: #fff; }
.wb-vlabel--on-accent { background: rgba(255,255,255,0.16); color: #fff; }
/* エンジ面の英字見出し */
.wb-sh__en--on-accent { color: #fff; opacity: 0.12; margin-bottom: 0.8rem; }
/* 院長セクション:写真あり時は2カラム(エンジ面+実写) */
.wb-doctor-section { padding: 0; overflow: hidden; }
.wb-doctor-wrap { max-width: 1600px; margin: 0 auto; }
/* 写真ありのとき:エンジ面は中央コンテナ左半分、写真は右端へ抜ける */
.wb-doctor-wrap .wb-panel-accent.has-photo {
	display: grid; grid-template-columns: 1fr 50vw; gap: 0; padding: 0; max-width: none; align-items: stretch;
	margin-right: calc(-50vw + 50%); /* 右端を画面外へ抜く */
}
.wb-panel-accent.has-photo { display: grid; grid-template-columns: 1.15fr 1fr; gap: 0; padding: 0; max-width: none; align-items: stretch; }
.wb-panel-accent.has-photo .wb-panel-accent__body { padding: clamp(2rem, 3vw, 3rem) clamp(1.8rem, 3vw, 2.8rem); max-width: none; align-self: center; }
/* エンジ面内ではvlabelのfloatを解除(縦組み折返しバグの解消) */
.wb-panel-accent.has-photo .wb-vlabel { float: none; display: inline-block; writing-mode: horizontal-tb; background: rgba(255,255,255,0.16); padding: 0.3em 1em; margin: 0 0 1.2rem; letter-spacing: 0.15em; }
.wb-panel-accent.has-photo .wb-panel-accent__body h2 { font-size: clamp(1.5rem, 2.8vw, 2.2rem); line-height: 1.6; letter-spacing: 0.06em; font-weight: 400; }
.wb-panel-accent.has-photo .wb-panel-accent__body p { line-height: 2.1; font-size: clamp(0.92rem, 1.2vw, 1rem); }
.wb-panel-accent__photo { position: relative; min-height: 100%; }
.wb-panel-accent__photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; }
@media (max-width: 820px) {
	.wb-doctor-wrap .wb-panel-accent.has-photo { grid-template-columns: 1fr; margin-right: 0; }
	.wb-panel-accent.has-photo { grid-template-columns: 1fr; }
	.wb-panel-accent__photo { height: 70vw; order: -1; }
	.wb-panel-accent__photo img { position: static; }
}
/* お知らせ */
.wb-news { list-style: none; padding: 0; margin: 1.2rem 0 0; }
.wb-news li { display: flex; gap: 1.2rem; padding: 0.7rem 0; border-bottom: 1px solid var(--wb-line, #D3D4D6); font-size: 0.92rem; }
.wb-news time { color: #919196; white-space: nowrap; }
.wb-news a { color: var(--wb-text); text-decoration: none; }
.wb-news a:hover { color: var(--wb-accent); }
/* ── FV(ファーストビュー):全面キービジュアル+左余白オーバーレイ ── */
.wb-fv { position: relative; background: #EAEBED; isolation: isolate; overflow: hidden; }
.wb-fv__inner { position: relative; }
/* 画像は独立レイヤーへ分離(読み込み時に単独でフェードイン+スクロールで微ドリフトさせるため) */
.wb-fv.has-img .wb-fv__media {
	position: absolute; inset: 0; z-index: 0;
	background-image: var(--fv-img);
	background-size: cover;
	background-position: 88% center;
	background-repeat: no-repeat;
	filter: url(#wb-fv-tone);
}
/* FVクロスフェードスライド */
.wb-fv__slides {
	position: absolute; inset: 0; z-index: 0;
}
.wb-fv__slide {
	position: absolute; inset: 0;
	background-size: cover;
	background-position: 88% center;
	background-repeat: no-repeat;
	filter: url(#wb-fv-tone);
	opacity: 0;
	animation: wb-fv-crossfade calc(var(--fv-total, 4) * 7s) infinite;
}
@keyframes wb-fv-crossfade {
	0%   { opacity: 0; }
	4%   { opacity: 1; }
	21%  { opacity: 1; }
	25%  { opacity: 0; }
	100% { opacity: 0; }
}
/* softモードのダークグラデーションをスライドにも適用 */
.wb-fv--soft.has-img .wb-fv__slides::after {
	content: "";
	position: absolute; inset: 0; z-index: 1;
	background:
		linear-gradient(to top, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.25) 30%, rgba(0,0,0,0.08) 55%, rgba(0,0,0,0) 75%),
		linear-gradient(to right, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0) 50%);
	pointer-events: none;
}
/* 白フェードの足場(背景は方式別に指定。下記2方式をカスタマイザーで切替) */
.wb-fv.has-img .wb-fv__overlay::before {
	content: "";
	position: absolute; inset: 0;
	pointer-events: none;
}
/* 方式A(従来):左フェードのみ */
.wb-fv--left.has-img .wb-fv__overlay::before {
	background:
		/* 横:左のコピー周辺だけ明るく。中央より手前で透明に=女性側はほぼ素の画像 */
		linear-gradient(100deg, rgba(255,255,255,0.80) 0%, rgba(255,255,255,0.62) 20%, rgba(255,255,255,0.28) 36%, rgba(255,255,255,0.05) 48%, rgba(255,255,255,0) 56%),
		/* 上:ヘッダー周辺のごく薄い足場のみ */
		linear-gradient(180deg, rgba(255,255,255,0.60) 0%, rgba(255,255,255,0.22) 10%, rgba(255,255,255,0) 18%);
}
/* 方式:soft(推奨) 「左に白い面/壁」を消す。
   ポイント1=フェードを中央寄せ列(::before)ではなく画像の全幅レイヤー(::after)に置く→矩形の縁が出ない。
   ポイント2=直線の帯ではなく楕円のソフトグロー→等高線が曲線になり“面/帯”に見えない。
   ポイント3=濃い面を作らずピークを下げ、最初からなだらかに薄れ、右側(女性)では消える。 */
.wb-fv--soft.has-img .wb-fv__media::after {
	content: "";
	position: absolute; inset: 0;
	background:
		linear-gradient(to top, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.25) 30%, rgba(0,0,0,0.08) 55%, rgba(0,0,0,0) 75%),
		linear-gradient(to right, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0) 50%);
	pointer-events: none;
}
/* 方式:veil 全面ヴェール＋左にごく弱い補助フェード */
/* (1)画像全体にごく薄いグレージュのヴェール=空気を整える。英字より下のレイヤーなので英字は埋もれない */
.wb-fv--veil.has-img .wb-fv__media::after {
	content: "";
	position: absolute; inset: 0;
	background: rgba(234, 235, 237, 0.10);
	pointer-events: none;
}
/* (2)左35%前後だけ、境界が出ないようゆるやかな補助フェード */
.wb-fv--veil.has-img .wb-fv__overlay::before {
	background:
		linear-gradient(100deg, rgba(255,255,255,0.34) 0%, rgba(255,255,255,0.16) 18%, rgba(255,255,255,0.04) 30%, rgba(255,255,255,0) 40%),
		linear-gradient(180deg, rgba(255,255,255,0.30) 0%, rgba(255,255,255,0) 16%);
}
/* ヘッダー高さ分、FVの中身を下げてヘッダーと重ならないように */
.home .wb-fv__overlay { padding-top: 6.5rem; }
.home .wb-fv:not(.has-img) .wb-fv__overlay { padding-top: 6.5rem; }
.wb-fv__overlay { position: relative; z-index: 1; max-width: 1280px; margin: 0 auto; min-height: 86vh; display: flex; align-items: center; }
.wb-fv__copy { position: relative; z-index: 1; max-width: 32rem; padding: 2rem 1rem 2rem 2.4rem; }
.wb-fv__label { font-size: 0.93rem; font-weight: 600; letter-spacing: 0.12em; color: rgba(255,255,255,0.75); margin: 0 0 1.6rem; }
.wb-fv__catch { font-family: var(--wb-serif); font-weight: 400; font-size: clamp(2rem, 3.8vw, calc(2.9rem + 2px)); line-height: 1.55; letter-spacing: 0.04em; margin: 0 0 1.6rem; color: #fff; }
.wb-fv__catch-line { display: block; }
.wb-fv__lead { font-size: clamp(1.08rem, 1.6vw, 1.19rem); font-weight: 500; line-height: 2; color: rgba(255,255,255,0.85); margin: 0 0 2rem; }
.wb-fv .wb-textlink { color: rgba(255,255,255,0.85); border-color: rgba(255,255,255,0.4); font-weight: 600; font-size: 1.05rem; }
@media (min-width: 821px) {
	/* PCでは見出しを必ず2行に保つ(各行は折り返さない) */
	.wb-fv__catch-line { white-space: nowrap; }
}
@media (max-width: 820px) {
	/* スマホ:内ページと同じテキスト重ね表示 */
	.wb-fv.has-img .wb-fv__media {
		background-position: 72% center;
	}
	.wb-fv__slide {
		background-position: 72% center;
	}
	.wb-fv__overlay { min-height: 100svh; align-items: flex-end; }
	.wb-fv__overlay::before { display: none !important; }
	.wb-fv__copy { max-width: none; padding: 0 1.25rem 2.5rem; }
	.wb-fv__catch { font-size: 1.6rem; }
}
@media (max-width: 820px) {
	/* スマホ:ヘッダー透過維持 */
	.home .wb-header { background: transparent; border-bottom: none; }
	.home .wb-header:not(.is-sticky) .wb-header__logo-text { color: #fff; }
	.home .wb-header:not(.is-sticky) .wb-nav a { color: rgba(255,255,255,0.85); }
	.home .wb-header:not(.is-sticky) .wb-nav a:hover { color: #fff; }
	.home .wb-fv__overlay { padding-top: 0; }
}
/* 画像未設定時のプレースホルダー */
.wb-fv:not(.has-img) .wb-fv__overlay { min-height: 60vh; }
.wb-fv:not(.has-img) .wb-fv__copy::after { content: "（FV画像をカスタマイザーで設定してください）"; display: block; margin-top: 1.5rem; font-size: 0.8rem; color: #aaa; }

/* ── FVモーション:読み込み時の静かなフェードイン ── */
/* コピーは少し下から上へ静かに持ち上がる。画像はやや遅れて。スクロールの微ドリフトはJS(wb-fv.js) */
@keyframes wbFvRise { from { opacity: 0; transform: translate3d(0, 22px, 0); } to { opacity: 1; transform: translate3d(0, 0, 0); } }
@keyframes wbFvFade { from { opacity: 0; } to { opacity: 1; } }
@keyframes wbFvMedia { from { opacity: 0; transform: translate3d(0, 18px, 0); } to { opacity: 1; transform: translate3d(0, 0, 0); } }

.wb-fv__media { opacity: 0; animation: wbFvMedia 1.7s cubic-bezier(0.22, 0.61, 0.36, 1) 0.5s both; } /* 画像:コピーより遅れて、静かに浮かび上がる */
.wb-fv__slides { opacity: 0; animation: wbFvMedia 1.7s cubic-bezier(0.22, 0.61, 0.36, 1) 0.5s both; }
/* easeInOutSine:始まりも終わりもゆるやか=“スン”とせず、静かに持ち上がる */
/* 見出しは2行を別々に、一段ゆっくり持ち上げて“一呼吸”を入れる。ラベル/リード/CTAは従来どおり */
.wb-fv__label,
.wb-fv__catch-line,
.wb-fv__lead,
.wb-fv__copy > .wb-textlink {
	opacity: 0;
	animation: wbFvRise 1.5s cubic-bezier(0.445, 0.05, 0.55, 0.95) both;
}
.wb-fv__catch-line { animation-duration: 1.8s; } /* 見出しは一段ゆっくり */
.wb-fv__label                   { animation-delay: 0.15s; }
.wb-fv__catch-line:nth-child(1) { animation-delay: 0.45s; } /* 口元の美しさを、 */
.wb-fv__catch-line:nth-child(2) { animation-delay: 1.30s; } /* 一呼吸おいて → 見た目だけで終わらせない。 */
.wb-fv__lead                    { animation-delay: 2.00s; }
.wb-fv__copy > .wb-textlink     { animation-delay: 2.25s; }
.wb-fv__inner { will-change: transform; } /* スクロールドリフトの合成最適化 */

@media (prefers-reduced-motion: reduce) {
	/* 上部のグローバル指定でanimationが無効化されるため、初期opacity:0で要素が消えないよう明示的に可視化 */
	.wb-fv__media, .wb-fv__copy > *, .wb-fv__catch-line, .wb-fv__inner { opacity: 1 !important; transform: none !important; animation: none !important; }
}

/* ── FV英字タイポグラフィ(写真の上に薄く重ねるポスター的レイヤー) ── */
/* 重ね順: 画像 < 白フェード(overlay::before) < 英字(.wb-fv__en) < 日本語コピー(z-index:1) */
.wb-fv__en {
	position: absolute;
	top: 50%; left: 2.4rem; right: 0;
	transform: translateY(-50%);
	pointer-events: none;
	user-select: none;
	font-family: var(--wb-display);
	font-weight: 400;
	text-transform: uppercase;
	line-height: 0.9;
	letter-spacing: 0.01em;
	white-space: nowrap;
	opacity: var(--wb-fv-en-opacity, 0.1);
}
.wb-fv__en--grey  { color: var(--wb-text); }
.wb-fv__en--white { color: #ffffff; }
.wb-fv__en-row { display: block; }
.wb-fv__en--stack .wb-fv__en-row { font-size: clamp(2.6rem, 9.5vw, 8.5rem); }
.wb-fv__en--line  .wb-fv__en-row { font-size: clamp(1.8rem, 7vw, 6rem); }
@media (max-width: 820px) {
	.wb-fv__en { display: none; } /* スマホは画像とコピーが上下分離のため英字は一旦非表示 */
}

/* ── 透明な装置セクション:横抜けレイアウト(flexベース) ── */
.wb-clear { padding: clamp(3.5rem, 7vw, 6rem) 0; overflow: hidden; }
.wb-clear__inner { display: flex; align-items: center; gap: clamp(2rem, 4vw, 4rem); max-width: 1600px; margin: 0 auto; }
/* 画像ブロック:画面左端(0)から始まり、コピーの手前まで。左に抜ける */
.wb-clear.has-img .wb-clear__visual {
	flex: 0 1 62%;
	margin-left: calc(-50vw + 50%);
	min-width: 0;
}
.wb-clear__visual img { width: 100%; height: 56vh; max-height: 480px; object-fit: cover; object-position: center; display: block; border-radius: 0 2px 2px 0; }
/* コピーは右側、中央コンテナの右半分に収まる位置へ */
.wb-clear__copy { flex: 0 1 26rem; padding-right: 1.5rem; text-align: left; }
.wb-clear__title { font-family: var(--wb-serif); font-size: clamp(1.6rem, 2.7vw, 2.1rem); font-weight: 400; letter-spacing: 0.06em; line-height: 1.6; margin: 0 0 1.6rem; color: var(--wb-text); }
.wb-clear__title .wb-indent { display: block; padding-left: 2em; }
@media (max-width: 600px) { .wb-clear__title .wb-indent { padding-left: 1em; } }
.wb-clear__text { line-height: 2.1; color: #4a4a4e; margin: 0 0 1.2rem; font-size: clamp(0.92rem, 1.2vw, 1rem); }
@media (max-width: 820px) {
	.wb-clear { padding: 3rem 0; }
	.wb-clear__inner { flex-direction: column; gap: 1.5rem; align-items: stretch; }
	.wb-clear.has-img .wb-clear__visual { flex: none; }
	.wb-clear__visual img { height: 56vw; border-radius: 0; }
	.wb-clear__copy { max-width: none; padding: 0 1.25rem; }
}
/* ── 治療の流れ:ステップタイムライン ── */
/* 使い方:番号付きリスト(ol)に is-style-wb-flow クラスを付与 */
.wb-content ol.is-style-wb-flow {
	list-style: none;
	counter-reset: wbflow;
	padding: 0;
	margin: 1.5rem 0;
	position: relative;
}
.wb-content ol.is-style-wb-flow > li {
	counter-increment: wbflow;
	position: relative;
	padding: 0 0 1.6rem 3.4rem;
	margin: 0;
}
/* 縦線(最後のステップだけ線を消す) */
.wb-content ol.is-style-wb-flow > li::before {
	content: "";
	position: absolute;
	left: 1.05rem; top: 2.2rem; bottom: -0.2rem;
	width: 1px;
	background: var(--wb-line, #D3D4D6);
}
.wb-content ol.is-style-wb-flow > li:last-child::before { display: none; }
/* 番号バッジ */
.wb-content ol.is-style-wb-flow > li::after {
	content: counter(wbflow);
	position: absolute;
	left: 0; top: 0;
	width: 2.2rem; height: 2.2rem;
	display: flex; align-items: center; justify-content: center;
	background: #fff;
	border: 1.5px solid var(--wb-accent);
	color: var(--wb-accent);
	border-radius: 50%;
	font-family: var(--wb-serif);
	font-size: 0.95rem;
	font-weight: 600;
	line-height: 1;
}
.wb-content ol.is-style-wb-flow > li strong { display: block; margin-bottom: 0.15em; }
@media (max-width: 480px) {
	.wb-content ol.is-style-wb-flow > li { padding-left: 3rem; }
}
/* ── 症例(case) ── */
.wb-case-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin: 1.6rem 0; }
@media (max-width: 820px) { .wb-case-grid { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; } }
.wb-case-card { background: #fff; border: 1px solid var(--wb-line, #D3D4D6); border-radius: 2px; overflow: hidden; display: flex; flex-direction: column; }
.wb-case-card__media { display: block; text-decoration: none; }
.wb-case-card__media figure { margin: 0; position: relative; }
.wb-case-card__media img { width: 100%; height: auto; display: block; }
.wb-case-card__media figcaption { position: absolute; left: 0; top: 0; background: rgba(46,46,44,0.66); color: #fff; font-size: 0.72rem; letter-spacing: 0.08em; padding: 0.2em 0.7em; }
.wb-case-card__chief { font-family: var(--wb-serif); font-size: 1.05rem; font-weight: 600; color: var(--wb-accent); margin: 1rem 1.2rem 0.6rem; }
.wb-case-card__meta { margin: 0 1.2rem 0.8rem; padding: 0; font-size: 0.84rem; }
.wb-case-card__meta div { display: flex; gap: 0.6em; padding: 0.25em 0; border-bottom: 1px dotted var(--wb-line, #D3D4D6); }
.wb-case-card__meta dt { color: #87878c; white-space: nowrap; margin: 0; min-width: 4.5em; }
.wb-case-card__meta dd { margin: 0; }
.wb-case-card__link { display: block; margin: auto 1.2rem 1.1rem; padding-top: 0.5rem; font-size: 0.82rem; color: var(--wb-accent); text-decoration: none; }
.wb-case-card__link:hover { text-decoration: underline; }
/* 症例個別ページ */
.wb-case-single__media { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin: 1.5rem 0; }
@media (max-width: 560px) { .wb-case-single__media { grid-template-columns: 1fr; } }
.wb-case-single__media figure { margin: 0; }
.wb-case-single__media img { width: 100%; height: auto; border: 1px solid var(--wb-line, #D3D4D6); }
.wb-case-single__media figcaption { font-size: 0.82rem; color: #87878c; margin-top: 0.4em; text-align: center; }
.wb-case-table { width: 100%; border-collapse: collapse; margin: 1.5rem 0; font-size: 0.92rem; }
.wb-case-table th, .wb-case-table td { border: 1px solid var(--wb-line, #D3D4D6); padding: 0.7rem 0.9rem; text-align: left; vertical-align: top; }
.wb-case-table th { background: #F1F2F3; white-space: nowrap; width: 9em; font-weight: 600; }
.wb-case-note { background: #F1F2F3; border-left: 3px solid var(--wb-accent); padding: 1rem 1.2rem; margin: 1.5rem 0; font-size: 0.84rem; color: #65656a; }
.wb-case-note p { margin: 0 0 0.6em; }
.wb-case-note p:last-child { margin-bottom: 0; }
.wb-breadcrumb { font-size: 0.8rem; color: #87878c; margin-bottom: 1rem; }
.wb-breadcrumb a { color: var(--wb-accent); text-decoration: none; }
.wb-case-back { margin-top: 2rem; }
.wb-case-back a { color: var(--wb-accent); text-decoration: none; }

/* ============ 共通ブロック(費用/リスク/医院) ============ */
.wb-block {
	background: var(--wb-bg);
	border: 1px solid var(--wb-line);
	border-radius: var(--wb-radius);
	padding: 1.6rem 1.8rem;
	margin: 2rem 0;
}
.wb-block--fee { border-left: 3px solid var(--wb-accent); }
.wb-block__note { font-size: 0.92rem; margin-top: 0; }

.wb-fee, .wb-clinic { margin: 0; }
.wb-fee dt, .wb-clinic dt {
	font-weight: 700; font-size: 0.88rem; color: var(--wb-accent);
	margin-top: 0.9em;
}
.wb-fee dd, .wb-clinic dd { margin: 0.15em 0 0; }

.wb-risk { padding-left: 1.3em; margin: 0; }
.wb-risk li { margin: 0.5em 0; }

.wb-clinic__name { font-family: var(--wb-serif); font-size: 1.1rem; font-weight: 600; margin: 0 0 0.1em; }
.wb-clinic__formal { font-size: 0.8rem; color: #6b6b67; margin: 0 0 0.6em; }



.wb-footer__clinic-name {
	font-weight: 500;
	font-size: 0.92rem;
	margin: 0 0 0.4rem;
}
.wb-footer__map {
	font-size: 0.72rem;
	letter-spacing: 0.08em;
	color: rgba(255,255,255,0.5);
	text-decoration: none;
	border: 1px solid rgba(255,255,255,0.25);
	padding: 0.15em 0.5em;
	border-radius: 2px;
	transition: color 0.2s, border-color 0.2s;
}
.wb-footer__map:hover { color: rgba(255,255,255,0.85); border-color: rgba(255,255,255,0.5); }
.wb-footer__hours {
	font-size: 0.82rem;
	color: rgba(255,255,255,0.6);
	margin: 0 0 0.2rem;
	line-height: 1.6;
}
.wb-footer__hours a { color: rgba(255,255,255,0.6); text-decoration: underline; }
.wb-footer__hours a:hover { color: rgba(255,255,255,0.85); }
.wb-footer__feature {
	font-size: 0.78rem;
	color: rgba(255,255,255,0.4);
	margin: 0 0 0.5rem;
	line-height: 1.6;
}

/* フッターナビ:カテゴリ構造 */
.wb-footer-nav {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: clamp(1.5rem, 3vw, 2.5rem);
	padding: 2rem 0;
	border-top: 1px solid rgba(255,255,255,0.1);
	margin-top: 1.5rem;
}
.wb-footer-nav__cat {
	font-family: var(--wb-display);
	font-size: 1.16rem;
	font-weight: 400;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.7);
	margin: 0 0 0.6rem;
}
.wb-footer-nav__cat span {
	display: block;
	font-family: var(--wb-sans);
	font-size: 0.65rem;
	letter-spacing: 0.06em;
	text-transform: none;
	color: rgba(255,255,255,0.35);
	margin-top: 0.15rem;
}
.wb-footer-nav ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.wb-footer-nav li { line-height: 1; }
.wb-footer-nav a {
	display: block;
	padding: 0.35rem 0;
	font-size: 0.78rem;
	color: rgba(255,255,255,0.45);
	text-decoration: none;
	transition: color 0.2s;
}
.wb-footer-nav a:hover { color: rgba(255,255,255,0.85); }
@media (max-width: 820px) {
	.wb-footer-nav { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
}
@media (max-width: 480px) {
	.wb-footer-nav { grid-template-columns: 1fr 1fr; }
}


/* フッター法人名(大きく) */
.wb-footer__corp--lg { font-size: 1.15rem; font-weight: 500; letter-spacing: 0.06em; }
/* フッターWEB予約リンク */
.wb-footer__reserve {
	display: inline-block;
	margin-top: 0.5rem;
	font-size: 0.78rem;
	letter-spacing: 0.06em;
	color: rgba(255,255,255,0.55);
	text-decoration: none;
	transition: color 0.2s;
}
.wb-footer__reserve:hover { color: rgba(255,255,255,0.9); }
.wb-footer__reserve strong { color: rgba(255,255,255,0.8); font-weight: 500; }

.wb-footer__formal { font-size: 0.78rem; opacity: 0.75; }
.wb-footer__note { font-size: 0.78rem; opacity: 0.75; margin-top: 0.4em; }

/* ============ 表(料金・装置比較) ============ */
.wb-table-wrap { overflow-x: auto; }
table.wb-table {
	width: 100%; border-collapse: collapse; font-size: 0.95rem;
	background: #fff;
}
.wb-table th, .wb-table td {
	border: 1px solid var(--wb-line);
	padding: 0.8em 1em; text-align: left; vertical-align: top;
}
.wb-table thead th { background: var(--wb-bg); font-family: var(--wb-serif); }

/* ============ FAQ ============ */
.wb-faq details {
	border-bottom: 1px solid var(--wb-line);
	padding: 0.4rem 0;
}
.wb-faq summary {
	cursor: pointer; font-weight: 700; padding: 0.8rem 0;
	list-style-position: outside;
}
.wb-faq summary::marker { color: var(--wb-accent); }
.wb-faq .a { padding: 0 0 1rem; }

/* ============ コンセプト:3つの柱(ys-dcのPromise風スタガー) ============ */
.wb-concept { padding: clamp(3.5rem, 7vw, 6rem) 0; overflow: hidden; }
.wb-concept__header { text-align: center; margin-bottom: clamp(3rem, 5vw, 5rem); }
.wb-concept__en {
	display: block;
	font-family: var(--wb-display);
	font-size: clamp(3.2rem, 7vw, 5.5rem);
	font-weight: 400;
	letter-spacing: 0.18em;
	line-height: 1;
	color: var(--wb-text);
	opacity: 0.2;
	text-transform: uppercase;
	margin-bottom: 0.6rem;
}
.wb-concept__title {
	font-family: var(--wb-serif);
	font-size: clamp(1.73rem, 3.2vw, 2.53rem);
	font-weight: 400;
	letter-spacing: 0.06em;
	line-height: 1.5;
	color: var(--wb-text);
	margin: 0;
}
.wb-concept__items {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1.5rem, 3vw, 2.5rem);
	max-width: var(--wb-maxw);
	margin: 0 auto;
	padding: 0 1.25rem;
}
/* 斜めスタガー:ys-dcのPromise配置を翻訳 */
@media (min-width: 821px) {
	.wb-concept__items .wb-concept__item:nth-child(2) { margin-top: 3.5rem; }
	.wb-concept__items .wb-concept__item:nth-child(3) { margin-top: 7rem; }
}
.wb-concept__item { padding: 0; }
.wb-concept__num {
	display: block;
	font-family: var(--wb-serif);
	font-size: clamp(0.85rem, 1.2vw, 1rem);
	font-weight: 600;
	letter-spacing: 0.15em;
	color: var(--wb-accent);
	margin-bottom: 1.2rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--wb-line);
}
.wb-concept__item-title {
	font-family: var(--wb-serif);
	font-size: clamp(1.58rem, 2.4vw, 1.83rem);
	font-weight: 400;
	letter-spacing: 0.04em;
	line-height: 1.6;
	color: var(--wb-text);
	margin: 0 0 1rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--wb-line);
}
.wb-concept__item-text {
	font-size: clamp(0.88rem, 1.1vw, 0.96rem);
	line-height: 2.1;
	color: #58585c;
	margin: 0;
}
@media (max-width: 820px) {
	.wb-concept__items { grid-template-columns: 1fr; max-width: 32rem; }
	.wb-concept__item { padding-bottom: 2rem; }
}

/* ============ 予約CTA(period.tokyo風:フッター直前の大型導線) ============ */
.wb-reserve {
	position: relative;
	overflow: hidden;
	padding: clamp(2.5rem, 5vw, 3.5rem) 0 0;
	background: #F1F2F3;
}
.wb-reserve__inner {
	max-width: var(--wb-maxw);
	margin: 0 auto;
	padding: 0 1.25rem;
	display: grid;
	grid-template-columns: 1fr 40%;
	gap: 2rem;
	align-items: end;
}
.wb-reserve__copy { padding-bottom: clamp(2rem, 4vw, 3rem); }
.wb-reserve__en {
	display: block;
	font-family: var(--wb-display);
	font-size: clamp(1.8rem, 3.2vw, 2.8rem);
	font-weight: 400;
	letter-spacing: 0.18em;
	line-height: 1;
	color: var(--wb-accent);
	margin-bottom: 0.5rem;
	text-transform: uppercase;
}
.wb-reserve__ja {
	font-family: var(--wb-serif);
	font-size: clamp(1rem, 1.6vw, 1.2rem);
	font-weight: 400;
	letter-spacing: 0.06em;
	color: var(--wb-text);
	margin: 0 0 1rem;
}
.wb-reserve__text {
	font-size: clamp(0.88rem, 1.2vw, 0.95rem);
	line-height: 2;
	color: #4a4a4e;
	margin: 0 0 1.5rem;
	max-width: 30em;
}
.wb-reserve__clinics {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	margin-bottom: 1.5rem;
}
.wb-reserve__clinic-card {
	background: rgba(255,255,255,0.7);
	border-radius: var(--wb-radius);
	padding: clamp(0.8rem, 1.5vw, 1rem) clamp(0.8rem, 1.5vw, 1.2rem);
}
.wb-reserve__clinic-name {
	font-family: var(--wb-serif);
	font-size: clamp(0.88rem, 1.3vw, 0.95rem);
	font-weight: 500;
	color: var(--wb-text);
	margin: 0 0 0.3rem;
}
.wb-reserve__clinic-tel {
	font-family: var(--wb-display);
	font-size: clamp(1.2rem, 2vw, 1.5rem);
	font-weight: 400;
	letter-spacing: 0.04em;
	color: var(--wb-text);
	text-decoration: none;
	display: block;
	margin-bottom: 0.4rem;
}
.wb-reserve__clinic-hours {
	font-size: 0.78rem;
	color: #58585c;
	margin: 0 0 0.15rem;
	line-height: 1.6;
}
.wb-reserve__clinic-closed {
	font-size: 0.75rem;
	color: #888;
	margin: 0 0 0.6rem;
}
.wb-reserve__clinic-btn {
	display: block;
	font-family: var(--wb-serif);
	font-size: 0.85rem;
	letter-spacing: 0.05em;
	color: #fff;
	background: #58585c;
	padding: 0.6em 1em;
	border-radius: 3px;
	text-decoration: none;
	text-align: center;
	transition: background 0.2s;
}
.wb-reserve__clinic-btn:hover {
	background: #3a3a3e;
}
.wb-reserve__tel {
	font-family: var(--wb-display);
	font-size: clamp(1.6rem, 2.8vw, 2.2rem);
	font-weight: 400;
	letter-spacing: 0.06em;
	color: var(--wb-text);
	text-decoration: none;
	display: block;
	margin-bottom: 0.4rem;
}
.wb-reserve__tel-note {
	font-size: 0.82rem;
	color: #87878c;
	margin: 0 0 2rem;
}
.wb-reserve__btn {
	display: inline-block;
	background: #58585c;
	color: #fff;
	font-family: var(--wb-serif);
	font-size: 1rem;
	letter-spacing: 0.08em;
	text-decoration: none;
	padding: 1em 3em;
	border-radius: var(--wb-radius);
	transition: background 0.2s ease;
	text-align: center;
}
.wb-reserve__btn:hover { background: #3a3a3e; }
.wb-reserve__btn small { display: block; font-family: var(--wb-display); font-size: 0.75rem; letter-spacing: 0.08em; opacity: 0.75; margin-bottom: 0.3em; }
/* 写真:グリッドの右カラム、下揃え */
.wb-reserve__photo { align-self: end; }
.wb-reserve__photo img { width: 100%; height: auto; display: block; max-height: 500px; object-fit: contain; object-position: bottom right; }
@media (max-width: 820px) {
	.wb-reserve__inner { grid-template-columns: 1fr; text-align: center; }
	.wb-reserve__copy { padding-bottom: 0; }
	.wb-reserve__text { margin-inline: auto; }
	.wb-reserve__clinics { grid-template-columns: 1fr; }
	.wb-reserve__photo { max-width: 280px; margin: 0 auto; }
}



/* ============ 症状SVGグリッド(カード置き換え) ============ */
.wb-symptoms {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: clamp(1rem, 2.5vw, 2rem);
	margin: 2.5rem 0;
	text-align: center;
}
.wb-symptom {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-decoration: none;
	color: var(--wb-text);
	padding: 1.5rem 0.5rem;
	border-radius: 2px;
	transition: transform 0.3s, background 0.3s;
}
.wb-symptom:hover { transform: translateY(-4px); background: rgba(255,255,255,0.7); }
.wb-symptom__icon {
	width: clamp(64px, 10vw, 88px);
	height: clamp(38px, 6vw, 52px);
	margin-bottom: 1rem;
}
.wb-symptom__name {
	font-family: var(--wb-serif);
	font-size: clamp(1rem, 1.4vw, 1.15rem);
	font-weight: 400;
	letter-spacing: 0.04em;
	margin-bottom: 0.3rem;
}
.wb-symptom__sub {
	font-size: 0.78rem;
	color: #87878c;
	line-height: 1.4;
}
@media (max-width: 600px) {
	.wb-symptoms { grid-template-columns: repeat(2, 1fr); }
}

/* ============ お悩み別導線:2カテゴリ横並び ============ */
.wb-concern-cols {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: clamp(2rem, 4vw, 4rem);
	align-items: start;
}
.wb-concern-group__title {
	font-family: var(--wb-serif);
	font-size: clamp(1.2rem, 1.7vw, 1.4rem);
	font-weight: 400;
	letter-spacing: 0.06em;
	color: var(--wb-accent);
	padding-bottom: 0.8rem;
	border-bottom: 1px solid var(--wb-line);
	margin: 0 0 1.2rem;
}
.wb-symptoms--list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0.8rem;
	margin: 0;
}
.wb-symptom--text { padding-top: 0.8rem; }
.wb-symptom--text .wb-symptom__name { color: var(--wb-accent); font-size: 0.92rem; }
.wb-concern-links { display: flex; flex-direction: column; gap: 0; }
.wb-concern-link {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	text-decoration: none;
	color: var(--wb-text);
	padding: 1rem 0;
	border-bottom: 1px solid var(--wb-line);
	transition: color 0.2s;
}
.wb-concern-link:first-child { padding-top: 0; }
.wb-concern-link:hover { color: var(--wb-accent); }
.wb-concern-link__name {
	font-family: var(--wb-serif);
	font-size: clamp(0.95rem, 1.3vw, 1.08rem);
	font-weight: 400;
	letter-spacing: 0.03em;
}
.wb-concern-link__sub {
	font-size: 0.78rem;
	color: #87878c;
	white-space: nowrap;
	margin-left: 1rem;
}
@media (max-width: 820px) {
	.wb-concern-cols { grid-template-columns: 1fr; }
	.wb-symptoms--list { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
	.wb-symptoms--list { grid-template-columns: 1fr 1fr; }
}

/* ============ 誠実さセクション(画像+FAQ付きv2) ============ */
.wb-honesty { background: transparent; padding: clamp(3.5rem, 7vw, 6rem) 0 clamp(1rem, 2vw, 2rem); overflow: hidden; }
.wb-honesty__inner {
	max-width: 1600px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 38% 1fr;
	gap: clamp(2.5rem, 5vw, 5rem);
	align-items: start;
}
.wb-honesty__visual {
	margin-left: calc(-50vw + 50%);
}
.wb-honesty__visual img {
	width: 100%;
	height: clamp(480px, 60vw, 680px);
	object-fit: cover;
	object-position: center 30%;
	display: block;
}
.wb-honesty__copy {
	padding: clamp(1rem, 2vw, 2rem) clamp(1rem, 3vw, 2rem) 0 0;
}
.wb-honesty__title {
	font-family: var(--wb-serif);
	font-size: clamp(1.3rem, 2.2vw, 1.7rem);
	font-weight: 400;
	letter-spacing: 0.04em;
	line-height: 1.6;
	color: var(--wb-text);
	margin: 0 0 0.6rem;
}
.wb-honesty__subtitle {
	font-family: var(--wb-serif);
	font-size: clamp(1.53rem, 2.6vw, 2.03rem);
	font-weight: 400;
	letter-spacing: 0.04em;
	line-height: 1.5;
	color: var(--wb-text);
	margin: 0 0 1.4rem;
}
.wb-honesty__text {
	font-size: clamp(0.92rem, 1.2vw, 1rem);
	line-height: 2.1;
	color: #58585c;
	margin: 0 0 1rem;
}
/* FAQ: 静かな罫線リスト */
.wb-honesty__faq-heading {
	font-family: var(--wb-serif);
	font-size: clamp(0.95rem, 1.3vw, 1.08rem);
	font-weight: 400;
	color: var(--wb-text);
	margin: 2rem 0 0.6rem;
}
.wb-honesty__faq {
	list-style: none;
	padding: 0;
	margin: 0 0 1.8rem;
	border-top: 1px solid var(--wb-line);
}
.wb-honesty__faq li { border-bottom: 1px solid var(--wb-line); }
.wb-honesty__faq a {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 1rem 0.2rem;
	text-decoration: none;
	color: #4a4a4e;
	font-size: clamp(0.9rem, 1.2vw, 0.98rem);
	line-height: 1.5;
	transition: color 0.2s;
}
.wb-honesty__faq a:hover { color: var(--wb-accent); }
.wb-honesty__faq .wb-faq-arrow {
	flex-shrink: 0;
	margin-left: 1rem;
	font-size: 0.9rem;
	color: #b0b0b4;
	transition: color 0.2s;
}
.wb-honesty__faq a:hover .wb-faq-arrow { color: var(--wb-accent); }
@media (max-width: 820px) {
	.wb-honesty__inner { grid-template-columns: 1fr; }
	.wb-honesty__visual { margin-left: 0; order: -1; }
	.wb-honesty__visual img { min-height: 250px; height: 50vw; }
	.wb-honesty__copy { padding: 0 1.25rem; }
}




/* 白蛍光ペン風ハイライト */
.wb-highlight {
	background: linear-gradient(transparent 55%, rgba(255,255,255,0.6) 55%);
	padding: 0 0.15em;
}

/* スマホのみ改行 */
.wb-sp-only { display: none; }
@media (max-width: 820px) { .wb-sp-only { display: inline; } }

/* ============ 院長プロフィール v2: 画像+テキスト2カラム ============ */
.wb-director-v2 { padding: clamp(3.5rem, 7vw, 6rem) 0; overflow: hidden; background: #F1F2F3; }
.wb-director-v2__inner {
	max-width: 1600px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 38% 1fr;
	gap: clamp(2.5rem, 5vw, 5rem);
	align-items: start;
}
.wb-director-v2__visual { margin-left: calc(-50vw + 50%); }
.wb-director-v2__visual img {
	width: 100%;
	height: clamp(480px, 60vw, 680px);
	object-fit: cover;
	object-position: center 20%;
	display: block;
}
.wb-director-v2__copy {
	padding: clamp(1rem, 2vw, 2rem) clamp(1rem, 3vw, 2rem) 0 0;
}
@media (max-width: 820px) {
	.wb-director-v2__inner { grid-template-columns: 1fr; }
	.wb-director-v2__visual { margin-left: 0; order: -1; }
	.wb-director-v2__visual img { height: 50vw; }
	.wb-director-v2__copy { padding: 0 1.25rem; }
}

/* ============ 院長プロフィール(Philosophy直下) ============ */
.wb-director__inner { max-width: 38em; }
.wb-director__name {
	font-family: var(--wb-serif);
	font-size: clamp(1.15rem, 1.8vw, 1.4rem);
	font-weight: 400;
	letter-spacing: 0.12em;
	color: var(--wb-text);
	margin: 0.5rem 0 1.8rem;
}
.wb-director__body .wb-director__lead {
	font-family: var(--wb-serif);
	font-size: clamp(1.3rem, 2.4vw, 1.8rem);
	font-weight: 400;
	letter-spacing: 0.04em;
	line-height: 1.7;
	color: var(--wb-text);
	margin: 0 0 2rem;
}
.wb-director__body p {
	font-size: clamp(0.92rem, 1.2vw, 1rem);
	line-height: 2.2;
	color: #58585c;
	margin: 0 0 1.2rem;
}


/* Fee & Risk 控えめバリアント */
.wb-sh__en--quiet {
	font-size: clamp(2rem, 4vw, 3rem) !important;
	opacity: 0.07 !important;
}
.wb-sh__ja--quiet {
	font-size: clamp(1.1rem, 1.8vw, 1.4rem) !important;
	color: #76767c;
}

/* Fee見出し: 明朝メイン + ゴシックサブ */
.wb-fee-headline {
	font-family: var(--wb-serif);
	font-size: clamp(1.2rem, 2vw, 1.6rem);
	font-weight: 400;
	letter-spacing: 0.04em;
	line-height: 1.7;
	color: var(--wb-text);
	margin: 0 0 0.6rem;
}
.wb-fee-sub {
	font-family: var(--wb-sans);
	font-size: 0.82rem;
	font-weight: 400;
	letter-spacing: 0.1em;
	color: #91919c;
	margin: 0 0 clamp(2rem, 3vw, 3rem);
}
/* 費用説明文(項目の下の1行補足) */
.wb-fee-col__desc {
	font-size: 0.85rem;
	line-height: 1.7;
	color: #76767c;
	margin: 0.3rem 0 1.2rem;
}
.wb-fee-col__list dd small {
	font-size: 0.78rem;
	color: inherit;
	margin-left: 0.2em;
}



/* Fee項目ラッパー(説明文の下に罫線) */
.wb-fee-item {
	padding-bottom: 0.8rem;
	margin-bottom: 0.8rem;
	border-bottom: 1px dotted var(--wb-line);
}
.wb-fee-item .wb-fee-col__desc { margin-bottom: 0; }
.wb-fee-col__list--no-border > div { border-bottom: none; }
/* マウスピース矯正の項目名を大きく */
.wb-fee-col__dt--lg { font-size: 1.05rem; }

/* Fee: 治療前にお伝えすること */
.wb-fee-col__explain {
	font-size: clamp(0.88rem, 1.1vw, 0.95rem);
	line-height: 2;
	color: #58585c;
	margin: 0;
}
/* Fee: ご確認ください */
.wb-fee-notice {
	margin-top: 2rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--wb-line);
}
.wb-fee-notice__heading {
	font-family: var(--wb-serif);
	font-size: clamp(0.92rem, 1.2vw, 1rem);
	font-weight: 400;
	color: var(--wb-text);
	margin: 0 0 0.5rem;
}
.wb-fee-notice__notes {
	font-size: 0.82rem;
	line-height: 1.8;
	color: #87878c;
	margin: 0;
}
.wb-fee-notice__text {
	font-size: 0.85rem;
	line-height: 1.7;
	color: #87878c;
	margin: 0;
}
.wb-fee-notice__title {
	font-family: var(--wb-serif);
	font-size: 0.88rem;
	font-weight: 400;
	letter-spacing: 0.06em;
	color: #76767c;
	margin: 0 0 0.6rem;
}
.wb-fee-notice__list {
	list-style: none;
	padding: 0;
	margin: 0;
}
.wb-fee-notice__list {
	display: flex;
	flex-wrap: wrap;
	gap: 0 1.5rem;
}
.wb-fee-notice__list li {
	font-size: 0.82rem;
	line-height: 1.8;
	color: #87878c;
}
.wb-fee-notice__list li::before { content: "※ "; }
/* Fee: CTA主従 */
.wb-fee-cta-primary {
	display: inline-block;
	font-family: var(--wb-serif);
	font-size: 1rem;
	letter-spacing: 0.08em;
	color: var(--wb-accent);
	text-decoration: none;
	padding: 0.9em 2.2em;
	border: 1px solid var(--wb-accent);
	border-radius: var(--wb-radius);
	transition: background 0.2s, color 0.2s;
	margin-right: 0;
}
.wb-fee-cta-primary:hover { background: var(--wb-accent); color: #fff; }

/* ============ 料金・リスク概要 ============ */
.wb-fee-cols {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 4vw, 3.5rem);
	margin-bottom: 2rem;
}
.wb-fee-col__title {
	font-family: var(--wb-serif);
	font-size: clamp(1rem, 1.4vw, 1.15rem);
	font-weight: 400;
	letter-spacing: 0.04em;
	color: var(--wb-text);
	padding-bottom: 0.8rem;
	border-bottom: 1px solid var(--wb-line);
	margin: 0 0 1rem;
}
.wb-fee-col__list { margin: 0; }
.wb-fee-col__list > div {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: 0.6rem 0;
	border-bottom: 1px dotted var(--wb-line);
	font-size: 0.92rem;
}
.wb-fee-col__list dt { color: #58585c; margin: 0; white-space: nowrap; }
.wb-fee-col__list dd { margin: 0; text-align: right; font-family: var(--wb-serif); color: var(--wb-text); }
.wb-fee-col__risks {
	list-style: none;
	padding: 0;
	margin: 0;
}
.wb-fee-col__risks li {
	position: relative;
	padding: 0.5rem 0 0.5rem 1.2rem;
	font-size: 0.92rem;
	line-height: 1.8;
	color: #58585c;
	border-bottom: 1px dotted var(--wb-line);
}
.wb-fee-col__risks li::before {
	content: "";
	position: absolute;
	left: 0; top: 1rem;
	width: 6px; height: 6px;
	border-radius: 50%;
	background: var(--wb-line);
}
.wb-fee-col__note {
	font-size: 0.82rem;
	color: #87878c;
	margin: 1rem 0 0;
	line-height: 1.7;
}
.wb-fee-ctas {
	margin-top: 2.5rem;
	display: flex;
	align-items: center;
	gap: 2rem;
	flex-wrap: wrap;
}
@media (max-width: 600px) {
	.wb-fee-cols { grid-template-columns: 1fr; }
}


/* ============ 院長セクション v2: 白背景+大写真(エンジは差し色) ============ */
.wb-doctor-v2 { padding: clamp(3.5rem, 7vw, 6rem) 0; overflow: hidden; }
.wb-doctor-v2__inner {
	max-width: 1600px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 50%;
	gap: clamp(2rem, 4vw, 4rem);
	align-items: center;
}
.wb-doctor-v2__copy {
	padding-left: clamp(1.25rem, 3vw, 3rem);
}
.wb-doctor-v2__en {
	font-family: var(--wb-display);
	font-size: clamp(3.2rem, 7vw, 5.5rem);
	font-weight: 400;
	letter-spacing: 0.18em;
	line-height: 1;
	color: var(--wb-text);
	opacity: 0.2;
	text-transform: uppercase;
	margin-bottom: 0.6rem;
}
.wb-doctor-v2__title {
	font-family: var(--wb-serif);
	font-size: clamp(1.5rem, 2.8vw, 2.2rem);
	font-weight: 400;
	letter-spacing: 0.06em;
	line-height: 1.6;
	color: var(--wb-text);
	margin: 0 0 1.6rem;
}
.wb-doctor-v2__text {
	font-size: clamp(0.92rem, 1.2vw, 1rem);
	line-height: 2.1;
	color: #58585c;
	margin: 0 0 1rem;
}
.wb-doctor-v2__photo {
	margin-right: calc(-50vw + 50%);
}
.wb-doctor-v2__photo img {
	width: 100%;
	height: clamp(400px, 50vw, 620px);
	object-fit: cover;
	object-position: center top;
	display: block;
}
@media (max-width: 820px) {
	.wb-doctor-v2__inner { grid-template-columns: 1fr; }
	.wb-doctor-v2__photo { margin-right: 0; order: -1; }
	.wb-doctor-v2__photo img { height: 60vw; }
	.wb-doctor-v2__copy { padding: 0 1.25rem; }
}

/* (honesty v1 styles removed — v2 grid layout in use) */

/* ============ 全幅フォトブレイク(院内写真をドンと入れる) ============ */
.wb-photo-break {
	width: 100%;
	overflow: hidden;
	line-height: 0;
}
.wb-photo-break img {
	width: 100%;
	height: clamp(240px, 42vw, 520px);
	object-fit: cover;
	object-position: center;
	display: block;
}

/* ============ 診療セクション v2: 罫線リスト(ys-dc翻訳) ============ */
.wb-treatment-v2 { padding: clamp(3.5rem, 7vw, 6rem) 0; overflow: hidden; }
.wb-treatment-v2__inner {
	max-width: var(--wb-maxw);
	margin: 0 auto;
	padding: 0 1.25rem;
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: clamp(2rem, 5vw, 5rem);
	align-items: start;
}
/* 左カラム: 英字背景+見出し+リード */
.wb-treatment-v2__lead { position: relative; }
.wb-treatment-v2__en {
	font-family: var(--wb-display);
	font-size: clamp(3.2rem, 7vw, 5.5rem);
	font-weight: 400;
	letter-spacing: 0.18em;
	line-height: 1;
	color: var(--wb-text);
	opacity: 0.18;
	text-transform: uppercase;
	margin-bottom: 0.5rem;
}
.wb-treatment-v2__ja {
	font-family: var(--wb-serif);
	font-size: clamp(0.88rem, 1.2vw, 1rem);
	font-weight: 400;
	letter-spacing: 0.14em;
	color: #87878c;
	margin: 0 0 clamp(2rem, 3vw, 3rem);
}
.wb-treatment-v2__title {
	font-family: var(--wb-serif);
	font-size: clamp(1.5rem, 2.8vw, 2.2rem);
	font-weight: 400;
	letter-spacing: 0.04em;
	line-height: 1.7;
	color: var(--wb-text);
	margin: 0 0 1.2rem;
}
.wb-treatment-v2__text {
	font-size: clamp(0.9rem, 1.1vw, 0.96rem);
	line-height: 2.1;
	color: #58585c;
	margin: 0;
}
/* 右カラム: 番号付き罫線リスト */
.wb-treatment-list {
	list-style: none;
	padding: 0;
	margin: 0;
	border-top: 1px solid #c0c0c4;
}
.wb-treatment-list__item {
	border-bottom: 1px solid #c0c0c4;
}
.wb-treatment-list__link {
	display: grid;
	grid-template-columns: 2.5rem 1fr auto;
	align-items: baseline;
	gap: 0.8rem;
	padding: 1.4rem 0.2rem;
	text-decoration: none;
	color: var(--wb-text);
	transition: color 0.2s;
}
.wb-treatment-list__link:hover { color: var(--wb-accent); }
.wb-treatment-list__num {
	font-family: var(--wb-display);
	font-size: 0.82rem;
	font-weight: 400;
	letter-spacing: 0.1em;
	color: #b0b0b4;
}
.wb-treatment-list__name {
	font-family: var(--wb-serif);
	font-size: clamp(1.2rem, 1.8vw, 1.4rem);
	font-weight: 400;
	letter-spacing: 0.06em;
	color: var(--wb-text);
}
.wb-treatment-list__sub {
	display: block;
	font-family: var(--wb-sans);
	font-size: 0.78rem;
	color: #87878c;
	margin-top: 0.2rem;
	letter-spacing: 0.02em;
}
.wb-treatment-list__arrow {
	font-size: 0.9rem;
	color: #b0b0b4;
	transition: color 0.2s;
}
.wb-treatment-list__link:hover .wb-treatment-list__arrow { color: var(--wb-accent); }
@media (max-width: 820px) {
	.wb-treatment-v2__inner { grid-template-columns: 1fr; }
}

/* ============ フローティング予約ボタン ============ */
.wb-fab {
	position: fixed;
	bottom: 1.5rem;
	right: 1.5rem;
	z-index: 900;
	opacity: 0;
	transform: translateY(20px);
	pointer-events: none;
	transition: opacity 0.4s ease, transform 0.4s ease;
}
.wb-fab.is-visible {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}
.wb-fab__link {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.25rem;
	width: auto;
	padding: 10px 12px;
	border-radius: 6px;
	background: transparent;
	color: var(--wb-text);
	text-decoration: none;
	text-align: center;
	box-shadow: none;
	
	transition: box-shadow 0.2s, transform 0.15s;
}
.wb-fab__link:hover {
	box-shadow: none;
	transform: translateY(-2px);
}
.wb-fab__logo {
	width: 192px;
	height: auto;
	
}
.wb-fab__label {
	font-family: var(--wb-sans);
	font-size: 0.72rem;
	font-weight: 500;
	letter-spacing: 0.06em;
	line-height: 1;
	color: var(--wb-text);
	margin-top: 2px;
}
/* 画像ロゴ設定時はHTMLラベルを非表示(SVGフォールバック時は表示) */
img.wb-fab__logo ~ .wb-fab__label { display: none; }



/* ============ ヘッダートップナビ(ys-dc風6カテゴリ) ============ */
.wb-topnav {
	display: flex;
	align-items: center;
	gap: clamp(1.2rem, 2.8vw, 2.4rem);
	margin-right: auto;
}
.wb-topnav > a,
.wb-topnav__btn {
	font-family: var(--wb-display);
	font-size: clamp(0.92rem, 1.4vw, 1.08rem);
	font-weight: 400;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: #2e2e30;
	text-decoration: none;
	transition: color 0.2s;
	white-space: nowrap;
	appearance: none;
	border: none;
	background: transparent;
	cursor: pointer;
	padding: 0;
}
.wb-topnav > a:hover,
.wb-topnav__btn:hover { color: var(--wb-accent); }
.wb-topnav__toggle {
	appearance: none;
	border: none;
	background: transparent;
	cursor: pointer;
	display: flex;
	flex-direction: column;
	gap: 4px;
	width: 20px;
	padding: 6px 0;
	margin-left: 0.3rem;
}
.wb-topnav__toggle span {
	display: block;
	height: 1px;
	background: var(--wb-text);
}
@media (max-width: 820px) {
	.wb-topnav > a,
	.wb-topnav__btn { display: none; }
	.wb-topnav__toggle { width: 24px; gap: 5px; }
}

/* ============ ヘッダー:MENUボタン ============ */
.wb-menu-btn {
	appearance: none;
	border: none;
	background: transparent;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.4rem 0;
	color: var(--wb-text);
}
.wb-menu-btn__lines {
	display: flex;
	flex-direction: column;
	gap: 5px;
	width: 22px;
}
.wb-menu-btn__lines span {
	display: block;
	height: 1px;
	background: currentColor;
	transition: transform 0.3s, opacity 0.3s;
}
.wb-menu-btn__label {
	font-family: var(--wb-display);
	font-size: 0.78rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}
/* PC簡易ナビ */
.wb-nav--pc ul {
	display: flex;
	gap: clamp(1.2rem, 2.5vw, 2rem);
	list-style: none;
	padding: 0;
	margin: 0;
}
.wb-nav--pc a {
	font-size: 0.82rem;
	letter-spacing: 0.06em;
	color: var(--wb-text);
	text-decoration: none;
	transition: color 0.2s;
}
.wb-nav--pc a:hover { color: var(--wb-accent); }
@media (max-width: 820px) { .wb-nav--pc { display: none; } }

/* ============ フルスクリーンナビ ============ */
.wb-fullnav {
	position: fixed;
	inset: 0;
	z-index: 9999;
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.4s ease;
}
.wb-fullnav.is-open {
	pointer-events: auto;
	opacity: 1;
}
.wb-fullnav__overlay {
	position: absolute;
	inset: 0;
	background: rgba(52, 54, 58, 0.92);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}
.wb-fullnav__body {
	position: relative;
	z-index: 1;
	height: 100%;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	padding: clamp(4rem, 8vw, 6rem) clamp(2rem, 6vw, 6rem);
}
.wb-fullnav__close {
	position: fixed;
	top: 1.5rem;
	right: 1.5rem;
	z-index: 2;
	appearance: none;
	border: none;
	background: transparent;
	color: rgba(255,255,255,0.5);
	font-size: 1.8rem;
	cursor: pointer;
	transition: color 0.2s;
	line-height: 1;
}
.wb-fullnav__close:hover { color: #fff; }
.wb-fullnav__grid {
	max-width: 900px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 5vw, 4rem);
}
.wb-fullnav__col { display: flex; flex-direction: column; gap: clamp(2rem, 4vw, 3rem); }
.wb-fullnav__group {}
.wb-fullnav__cat {
	display: block;
	font-family: var(--wb-display);
	font-size: clamp(1.4rem, 3vw, 2rem);
	font-weight: 400;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.85);
	text-decoration: none;
	margin-bottom: 0.8rem;
	transition: color 0.2s;
}
.wb-fullnav__cat:hover { color: #fff; }
.wb-fullnav__cat span {
	display: block;
	font-family: var(--wb-sans);
	font-size: 0.72rem;
	letter-spacing: 0.08em;
	text-transform: none;
	color: rgba(255,255,255,0.4);
	margin-top: 0.2rem;
}
.wb-fullnav__list {
	list-style: none;
	padding: 0;
	margin: 0;
}
.wb-fullnav__list li { line-height: 1; }
.wb-fullnav__list a {
	display: block;
	padding: 0.55rem 0;
	font-size: clamp(0.85rem, 1.2vw, 0.95rem);
	color: rgba(255,255,255,0.55);
	text-decoration: none;
	letter-spacing: 0.04em;
	transition: color 0.2s;
}
.wb-fullnav__list a:hover { color: #fff; }
.wb-fullnav__sub { padding-left: 1.2rem; }
.wb-fullnav__sub a { font-size: 0.82rem; }
/* body scroll lock */
body.wb-nav-open { overflow: hidden; }
@media (max-width: 600px) {
	.wb-fullnav__grid { grid-template-columns: 1fr; gap: 2rem; }
	.wb-fullnav__body { padding: 3.5rem 1.5rem; }
}

/* ============ Footer ============ */
.wb-footer {
	background: var(--wb-text);
	color: var(--wb-bg);
	margin-top: 4rem;
	padding: 3rem 0 2rem;
	font-size: 0.88rem;
}
/* 予約CTAの直後はフッターの上マージンを詰める(period.tokyo風の繋がり) */
.wb-reserve + .wb-footer { margin-top: 0; }
.wb-footer a { color: var(--wb-bg); }
.wb-footer__corp { font-family: var(--wb-serif); font-size: 1rem; letter-spacing: 0.08em; }
.wb-footer__cols { display: flex; gap: 3rem; flex-wrap: wrap; margin: 1.5rem 0; }
/* フッター医院カード(区切り線付き・2x2グリッド) */
.wb-footer__clinics {
	display: grid !important;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	margin: 1.5rem 0;
}
.wb-footer__clinic {
	padding: 1.2rem 0;
	border-bottom: 1px solid rgba(255,255,255,0.1);
}
.wb-footer__clinic:nth-child(n+3) { border-bottom: none; }
.wb-footer__clinic:nth-child(odd) { padding-right: 1.5rem; border-right: 1px solid rgba(255,255,255,0.1); }
.wb-footer__clinic:nth-child(even) { padding-left: 1.5rem; }
.wb-footer__address {
	font-size: 0.82rem;
	color: rgba(255,255,255,0.6);
	margin: 0 0 0.3rem;
}
.wb-footer small { display: block; margin-top: 1.5rem; opacity: 0.7; }

/* ============ 本文(投稿・固定ページ) ============ */
.wb-content { max-width: 1000px; margin: 0 auto; padding: 2.5rem 1.25rem 4rem; }
.wb-content > h1 { font-size: 1.9rem; line-height: 1.6; }
@media (max-width: 600px) { .wb-content > h1 { font-size: 1.45rem; } }

/* ============================================================
   Symptoms Grid（TOPページ 症例イラストカード）
   ============================================================ */
.wb-symptom-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(0.8rem, 1.5vw, 1rem);
	margin-top: clamp(1.5rem, 3vw, 2rem);
}
.wb-symptom-card {
	display: block;
	border: 1px solid var(--wb-line);
	border-radius: var(--wb-radius);
	overflow: hidden;
	text-decoration: none;
	color: var(--wb-text);
	transition: box-shadow 0.3s;
}
.wb-symptom-card:hover {
	box-shadow: 0 4px 20px rgba(0,0,0,0.06);
}
.wb-symptom-card__img {
	position: relative;
	height: clamp(180px, 25vw, 240px);
	background: #F1F2F3;
	background-size: cover;
	background-position: center;
}
.wb-symptom-card__num {
	position: absolute;
	top: 16px;
	left: 18px;
	font-family: var(--wb-display);
	font-size: 11px;
	letter-spacing: 0.15em;
	color: rgba(255,255,255,0.6);
	writing-mode: vertical-rl;
}
.wb-symptom-card__num::before {
	content: 'No.';
	display: block;
	margin-bottom: 4px;
	font-size: 9px;
	letter-spacing: 0.12em;
}
.wb-symptom-card__body {
	padding: clamp(1rem, 2vw, 1.4rem) clamp(1rem, 2.5vw, 1.5rem) clamp(1.2rem, 2.5vw, 1.6rem);
}
.wb-symptom-card__en {
	display: block;
	font-family: var(--wb-display);
	font-size: 11px;
	letter-spacing: 0.12em;
	color: #aaa;
	text-transform: uppercase;
	margin-bottom: 4px;
}
.wb-symptom-card__title {
	display: block;
	font-family: var(--wb-serif);
	font-size: clamp(1.35rem, 2.5vw, 1.55rem);
	font-weight: 400;
	letter-spacing: 0.04em;
	margin-bottom: 4px;
}
.wb-symptom-card__reading {
	display: block;
	font-size: 0.78rem;
	color: #888;
	margin-bottom: clamp(0.6rem, 1vw, 0.8rem);
}
.wb-symptom-card__desc {
	display: block;
	font-size: clamp(0.82rem, 1.2vw, 0.88rem);
	line-height: 1.9;
	color: #58585c;
}
.wb-symptom-card__arrow {
	display: block;
	margin-top: clamp(0.6rem, 1vw, 0.8rem);
	font-family: var(--wb-display);
	font-size: 12px;
	letter-spacing: 0.08em;
	color: #aaa;
}
@media (max-width: 599px) {
	.wb-symptom-grid {
		grid-template-columns: 1fr;
	}
}

/* ============================================================
   SP調整：TOPページ（max-width: 820px）
   ============================================================ */
@media (max-width: 820px) {
	/* FVキャッチ +3pt */
	.wb-fv__catch { font-size: 1.79rem; }
	/* FVリード 1文字改行防止 */
	.wb-fv__lead { word-break: keep-all; overflow-wrap: break-word; }
	/* 透明な〜 +5pt */
	.wb-clear__title { font-size: 1.91rem; }
	/* お悩みSVG 1.5倍 */
	.wb-symptom__icon { width: clamp(96px, 15vw, 132px); height: clamp(57px, 9vw, 78px); }
	/* 費用の安さ〜 さらに-2pt */
	.wb-honesty__title { font-size: 0.98rem; }
	/* マウスピース矯正には〜 +3pt */
	.wb-honesty__subtitle { font-size: 1.53rem; }
	/* Philosophy その歯並び〜 +1pt */
	.wb-doctor-v2__title { font-size: 1.56rem; }
	/* Doctor 臨床に携わって〜 +1pt */
	.wb-director__body .wb-director__lead { font-size: 1.36rem; }
	/* Treatment 口元全体〜 +2pt */
	.wb-treatment-v2__title { font-size: 1.63rem; }
	/* Treatment メニュー名 +2pt */
	.wb-treatment-list__name { font-size: 1.33rem; }
	/* Fee & Risk 英字もう少し濃く */
	.wb-sh__en--quiet { opacity: 0.15 !important; }
	/* Reservation カウンセリング〜 +4pt */
	.wb-reserve__ja { font-size: 1.25rem; }
	/* Reservation まずは〜 -3pt（改行なし） */
	.wb-reserve__text { font-size: 0.88rem; }
	/* Reservation 医院名 +3pt */
	.wb-reserve__clinic-name { font-size: 1.07rem; }
}
