/* ===================================================================
   人間ドックの歯科版 ― 検査メニュー型リニューアル (2026-06-12)
   style.css + v2.css の後に読み込む
   =================================================================== */
.dock { --dock-gold:#BE8E44; --dock-gold-d:#9c7333; --dock-ink:#3a342e; }

/* ===================================================================
   HERO 2カラム（受付写真 + 左テキスト）
   =================================================================== */
.fv-hero2 { padding: 0 0 4rem; overflow: hidden; }
.fv-hero2 > .section-inner { padding-top: 3.4rem; }

/* ---- 背景写真バージョン（HEROバナー部分だけ背景） ---- */
.fv-hero2-banner.fv-hero2--bg { position: relative; overflow: hidden; padding: 4.6rem 0 4.6rem; }
.fv-hero2--bg .fv-hero2-bg { position: absolute; inset: 0; z-index: 0; }
.fv-hero2--bg .fv-hero2-bg img { width: 100%; height: 100%; object-fit: cover; object-position: 58% 64%; display: block; }
.fv-hero2--bg::before { content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(180deg, rgba(255,252,246,0.9) 0%, rgba(255,252,246,0.82) 45%, rgba(255,252,246,0.86) 100%); }
.fv-hero2--bg .section-inner { position: relative; z-index: 2; }
.fv-hero2--bg .fv-hero2-grid { grid-template-columns: 1fr; }
/* テキストをページ中央に */
.fv-hero2-banner.fv-hero2--bg .fv-hero2-text { max-width: 760px; margin: 0 auto; text-align: center; }
.fv-hero2-banner.fv-hero2--bg .fv-h2-line { text-align: center; }
.fv-hero2-banner.fv-hero2--bg .section-h2,
.fv-hero2-banner.fv-hero2--bg .section-lead,
.fv-hero2-banner.fv-hero2--bg .fv-firsttime-note { text-align: center; margin-left: auto; margin-right: auto; }
.fv-hero2-banner.fv-hero2--bg .fv-firsttime-tag { margin-left: auto; margin-right: auto; }
.fv-hero2-banner.fv-hero2--bg .fv-quote-bubble { margin-left: auto; margin-right: auto; }
.fv-hero2-banner.fv-hero2--bg .fv-script { display: block; text-align: center; }
.fv-hero2-banner.fv-hero2--bg .fv-script::after { margin-left: auto; margin-right: auto; }
.fv-hero2-banner.fv-hero2--bg .fv-stamp { position: absolute; top: 26px; right: 5%; left: auto; z-index: 4; width: 108px; height: 108px; }
@media (max-width: 820px) {
  .fv-hero2-banner.fv-hero2--bg { padding: 3.4rem 0 3.4rem; }
  .fv-hero2--bg::before { background: linear-gradient(180deg, rgba(255,252,246,0.94) 0%, rgba(255,252,246,0.9) 60%, rgba(255,252,246,0.86) 100%); }
  .fv-hero2-banner.fv-hero2--bg .fv-stamp { width: 84px; height: 84px; top: 14px; right: 4%; }
}
.fv-hero2 .fv-hero2-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(2rem, 4.5vw, 4.5rem);
  align-items: center;
  max-width: 1240px;
  margin: 0 auto;
}
/* --- 左：テキスト（中央寄せを左寄せに上書き） --- */
.fv-hero2 .fv-hero2-text { text-align: left; max-width: none; margin: 0; }
.fv-hero2 .fv-h2 { margin-top: 0.6rem; font-size: clamp(1.95rem, 3.7vw, 2.85rem) !important; margin-bottom: 1.3rem !important; }
.fv-hero2 .fv-h2-line { text-align: left; white-space: nowrap; }
.fv-hero2 .section-h2, .fv-hero2 .section-lead, .fv-hero2 .fv-firsttime-note { text-align: left; margin-left: 0; margin-right: 0; }
.fv-hero2 .fv-firsttime-tag { margin-left: 0; }
.fv-hero2 .fv-quote-bubble { margin-left: 0; margin-right: auto; }
.fv-hero2 .fv-firsttime-note { margin-top: 1.2rem; }
.fv-hero2 .section-lead { margin-top: 1rem; }
/* For your future（手書き） */
.fv-script {
  display: inline-block;
  font-family: 'Caveat', cursive;
  font-size: clamp(2rem, 3.4vw, 2.7rem);
  font-weight: 600;
  color: #E8A37C;
  line-height: 1;
  transform: rotate(-3deg);
  margin-bottom: 0.3rem;
}
.fv-script::after {
  content: "";
  display: block;
  width: 64%;
  height: 2px;
  margin-top: 0.15rem;
  background: linear-gradient(90deg, #F1C3A2, transparent);
  border-radius: 2px;
}
/* --- 右：メディア --- */
.fv-hero2 .fv-hero2-media { position: relative; }
.fv-hero2 .fv-hero2-photo {
  margin: 0;
  border-radius: 26px 26px 26px 90px;
  overflow: hidden;
  aspect-ratio: 4 / 3.4;
  box-shadow: 0 30px 60px rgba(150,120,80,0.20);
}
.fv-hero2 .fv-hero2-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* 水彩の葉っぱ風ブロブ（背景装飾） */
.fv-hero2 .fv-hero2-leaf {
  position: absolute;
  left: -52px; bottom: -36px;
  width: 230px; height: 200px;
  background: radial-gradient(closest-side, rgba(155,200,160,0.55), rgba(155,200,160,0) 72%);
  filter: blur(2px);
  z-index: 0;
  pointer-events: none;
}
/* 初診の方必見スタンプ（写真の左上に重ねる）― 上品なパステルピンク */
.fv-hero2 .fv-stamp {
  position: absolute; top: -22px; left: -22px; right: auto;
  width: 116px; height: 116px; z-index: 5;
  background: linear-gradient(135deg, #F6AEC2 0%, #E98AA6 100%);
  border: 3px solid #fff;
  box-shadow: 0 12px 26px rgba(220,130,160,0.34);
  filter: none;
}
.fv-hero2 .fv-stamp::before {
  inset: 9px;
  border: 1.5px solid rgba(255,255,255,0.85);
}
.fv-hero2 .fv-stamp .fv-stamp-text {
  font-size: 1.12rem;
  letter-spacing: 0.12em;
  text-shadow: 0 1px 3px rgba(180,80,110,0.28);
}
/* お口の健康手帳（写真の左下に浮かせる） */
.fv-hero2 .fv-hero2-note {
  position: absolute;
  left: -34px; bottom: -28px;
  width: clamp(120px, 13vw, 168px);
  margin: 0;
  border-radius: 12px;
  overflow: hidden;
  transform: rotate(-4deg);
  box-shadow: 0 16px 34px rgba(120,100,60,0.26);
  z-index: 4;
  border: 4px solid #fff;
}
.fv-hero2 .fv-hero2-note img { width: 100%; height: 100%; object-fit: cover; display: block; }

@media (max-width: 900px) {
  .fv-hero2 .fv-hero2-grid { grid-template-columns: 1fr; gap: 2.5rem; max-width: 560px; }
  .fv-hero2 .fv-hero2-media { margin-top: 0.5rem; }
  .fv-hero2 .fv-hero2-photo { aspect-ratio: 16 / 11; border-radius: 22px 22px 22px 64px; }
  .fv-hero2 .fv-stamp { width: 96px; height: 96px; top: -16px; left: -10px; }
  .fv-hero2 .fv-hero2-note { width: 130px; left: auto; right: -10px; bottom: -22px; }
}
@media (max-width: 560px) {
  .fv-hero2 .fv-hero2-note { width: 110px; }
}

.dock-head { max-width:740px; margin:0 auto 2.2rem; text-align:center; }
.dock-eyebrow { font-family:'Cormorant Garamond',serif; font-size:0.95rem; letter-spacing:0.32em; color:#BE8E44; margin:0 0 0.7rem; font-weight:600; }
.dock-h2 { font-family:'Noto Serif JP',serif; font-size:clamp(1.6rem,3.6vw,2.3rem); font-weight:600; color:#3a342e; line-height:1.5; margin:0 0 1rem; letter-spacing:0.03em; }
.dock-h2 em { font-style:normal; background-image:linear-gradient(120deg,#f3e3c2 0%,#e8cf9a 100%); background-repeat:no-repeat; background-size:100% 40%; background-position:0 78%; padding:0 .1em; border-radius:3px; }
.dock-lead { font-family:'Noto Serif JP',serif; font-size:1rem; line-height:2; color:#5b5349; margin:0; }

/* ---- 検査メニュー ---- */
.dock-menu { margin:3.5rem 0 1rem; }
.dock-sub { font-family:'Noto Serif JP',serif; text-align:center; font-size:1.2rem; font-weight:600; color:#3a342e; margin:0 0 1.6rem; position:relative; }
.dock-sub::after { content:""; display:block; width:42px; height:2px; background:#BE8E44; margin:0.7rem auto 0; border-radius:2px; }
.dock-grid { list-style:none; padding:0; margin:0 auto; max-width:840px; display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(0.9rem,1.8vw,1.3rem); }
.dock-card { background:#fff; border:1px solid #EDE3D2; border-radius:16px; overflow:hidden; box-shadow:0 12px 26px rgba(150,120,80,0.10); display:flex; flex-direction:column; }
.dock-card-photo, .dock-ph { width:100%; aspect-ratio:4/3; position:relative; overflow:hidden; }
.dock-card-photo img { width:100%; height:100%; object-fit:cover; display:block; }
.dock-ph { background:linear-gradient(135deg,#FBF4E8 0%,#F5ECDF 100%); display:flex; align-items:center; justify-content:center; }
.dock-ph span { font-size:0.86rem; color:#b39c7c; font-weight:600; letter-spacing:0.04em; }
.dock-ph::before { content:"PHOTO"; position:absolute; top:10px; left:10px; font-family:'Cormorant Garamond',serif; font-size:0.64rem; letter-spacing:0.2em; color:#fff; background:rgba(120,95,60,0.5); padding:0.15rem 0.55rem; border-radius:999px; }
.dock-card-body { padding:0.9rem 0.95rem 1.1rem; }
.dock-card-tag { display:inline-block; font-family:'Cormorant Garamond',serif; font-size:0.74rem; letter-spacing:0.12em; color:#BE8E44; font-weight:600; margin-bottom:0.3rem; }
.dock-card-body h4 { font-family:'Noto Serif JP',serif; font-size:1.02rem; font-weight:600; color:#3a342e; margin:0 0 0.4rem; }
.dock-card-body p { font-size:0.8rem; line-height:1.7; color:#6b6258; margin:0; }
@media(max-width:900px){ .dock-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:430px){ .dock-grid { grid-template-columns:1fr; max-width:340px; } }

/* ---- リスク評価（信号） ---- */
.dock-risk { margin:4rem 0 1rem; }
.dock-signals { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(0.9rem,2vw,1.4rem); max-width:840px; margin:0 auto; }
.dock-sig { background:#fff; border:1px solid #ECE4D6; border-radius:16px; padding:1.6rem 1.2rem; text-align:center; box-shadow:0 12px 26px rgba(150,120,80,0.08); }
.dock-sig-dot { width:46px; height:46px; border-radius:50%; display:inline-block; margin-bottom:0.8rem; box-shadow:0 0 0 6px rgba(0,0,0,0.04); }
.dock-sig--good .dock-sig-dot { background:radial-gradient(circle at 35% 30%,#9fe0ab,#46b06a); }
.dock-sig--warn .dock-sig-dot { background:radial-gradient(circle at 35% 30%,#ffe08a,#f0b528); }
.dock-sig--bad  .dock-sig-dot { background:radial-gradient(circle at 35% 30%,#ffb0a0,#e0654f); }
.dock-sig b { display:block; font-family:'Noto Serif JP',serif; font-size:1.15rem; color:#3a342e; margin-bottom:0.4rem; }
.dock-sig p { font-size:0.85rem; line-height:1.7; color:#6b6258; margin:0; }
@media(max-width:560px){ .dock-signals { grid-template-columns:1fr; max-width:320px; } }

/* ---- 結果は健康手帳でお渡し ---- */
.dock-result { display:grid; grid-template-columns:1.38fr 1fr; gap:clamp(2rem,4vw,3.4rem); align-items:center; max-width:1180px; margin:4rem auto 1.5rem; }
.dock-result-photo { margin:0; border-radius:22px; overflow:hidden; box-shadow:0 26px 56px rgba(150,120,80,0.18); }
.dock-result-photo img { width:100%; height:100%; object-fit:cover; display:block; }
.dock-result-text { text-align:left; }
.dock-result-text .dock-eyebrow { text-align:left; }
.dock-result-text .dock-h2 { text-align:left; font-size:clamp(1.9rem,3.3vw,2.4rem); line-height:1.5; }
.dock-result-text .dock-h2 .nb { white-space:nowrap; }
.dock-result-text .dock-lead { font-size:1rem; }
.dock-h2-br { display:inline; }
.dock-link { display:inline-block; margin-top:1.5rem; font-family:'Noto Serif JP',serif; font-weight:600; color:#9c7333; text-decoration:none; border-bottom:2px solid #e8cf9a; padding-bottom:2px; transition:color .3s; }
.dock-link:hover { color:#BE8E44; }
@media(max-width:820px){ .dock-result { grid-template-columns:1fr; max-width:560px; } .dock-result-text { text-align:center; } .dock-result-text .dock-h2, .dock-result-text .dock-eyebrow { text-align:center; } .dock-h2-br { display:none; } }

/* ---- YOUR RECORD : 記録の3つの特徴 + ひとことフォト（帯） ---- */
.dock-rec-strip { display:flex; align-items:center; justify-content:center; gap:clamp(1.4rem,3.5vw,3rem); flex-wrap:wrap; max-width:1000px; margin:0 auto 1rem; padding:1.9rem 2rem; background:linear-gradient(180deg,#FCFAF5,#F7F1E6); border-radius:22px; }
.dock-rec-feats { list-style:none; margin:0; padding:0; display:flex; gap:clamp(1rem,2.4vw,1.8rem); }
.dock-rec-feats li { display:flex; flex-direction:column; align-items:center; text-align:center; gap:.6rem; width:96px; }
.dock-rec-ic { width:64px; height:64px; border-radius:50%; background:#fff; box-shadow:0 6px 16px rgba(150,120,80,0.12); display:flex; align-items:center; justify-content:center; color:#BE8E44; }
.dock-rec-ic svg { width:28px; height:28px; }
.dock-rec-feats b { font-family:'Noto Serif JP',serif; font-weight:500; font-size:.82rem; line-height:1.45; color:#3a342e; }
.dock-rec-photo { position:relative; margin:0; width:208px; flex:0 0 auto; }
.dock-rec-photo img { width:100%; height:138px; object-fit:cover; display:block; border-radius:14px; box-shadow:0 14px 30px rgba(150,120,80,0.18); }
.dock-rec-note { position:absolute; top:-22px; right:-10px; transform:rotate(4deg); background:#FCF3D4; color:#3a342e; font-family:'Noto Serif JP',serif; font-weight:600; font-size:.72rem; line-height:1.45; text-align:center; padding:.55rem .75rem; border-radius:10px; box-shadow:0 6px 14px rgba(150,120,80,0.18); }
@media(max-width:560px){ .dock-rec-strip { padding:1.6rem 1.2rem; gap:1.6rem; } .dock-rec-feats { gap:.6rem; } .dock-rec-feats li { width:30%; } .dock-rec-ic { width:54px; height:54px; } .dock-rec-photo { width:200px; } .dock-rec-note { right:auto; left:-6px; } }
@media(max-width:420px){ .dock-rec-feats { gap:.4rem; } .dock-rec-feats li { width:31%; } .dock-rec-ic { width:50px; height:50px; } }

/* ---- なぜ定期的な検査が大切なの？ ---- */
.dock-why { max-width:1060px; margin:4.5rem auto 1rem; }
.dock-why-head { text-align:center; font-family:'Noto Serif JP',serif; font-weight:600; font-size:clamp(1.3rem,3vw,1.85rem); color:#3a342e; margin:0 0 2.1rem; letter-spacing:.04em; }
.dock-why-head em { font-style:normal; background-image:linear-gradient(120deg,#f3e3c2 0%,#e8cf9a 100%); background-repeat:no-repeat; background-size:100% 38%; background-position:0 82%; padding:0 .12em; border-radius:3px; }
.dock-why-grid { list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(1rem,2.2vw,1.6rem); }
.dock-why-card { display:flex; flex-direction:column; align-items:center; gap:.85rem; }
.dock-why-photo { position:relative; margin:0; border-radius:14px; overflow:hidden; aspect-ratio:1/1; width:100%; box-shadow:0 12px 26px rgba(150,120,80,0.16); }
.dock-why-photo img { width:100%; height:100%; object-fit:cover; display:block; }
.dock-why-bubble { --bub:#fff; position:relative; display:inline-flex; align-items:center; justify-content:center; min-height:2.84em; margin-bottom:.4rem; text-align:center; font-family:'Noto Serif JP',serif; font-weight:600; font-size:.84rem; line-height:1.42; color:#3a342e; padding:.5rem .95rem; border-radius:16px; background:var(--bub); box-shadow:0 6px 14px rgba(150,120,80,0.12); }
.dock-why-bubble::after { content:''; position:absolute; bottom:-8px; left:50%; transform:translateX(-50%); width:0; height:0; border:8px solid transparent; border-top-color:var(--bub); border-bottom:0; }
.dock-why-bubble[data-c="pink"] { --bub:#FCE1E9; }
.dock-why-bubble[data-c="mint"] { --bub:#DCF0E4; }
.dock-why-bubble[data-c="amber"] { --bub:#FBEDCF; }
.dock-why-bubble[data-c="blue"] { --bub:#DCEBF7; }
.dock-why-card > p { font-family:'Noto Serif JP',serif; font-size:.86rem; line-height:1.78; color:#5b5349; margin:0; }
@media(max-width:760px){ .dock-why-grid { grid-template-columns:repeat(2,1fr); gap:1.4rem 1rem; } }
@media(max-width:430px){ .dock-why-grid { grid-template-columns:1fr; max-width:320px; margin-inline:auto; } }

/* ---- 当日の流れ 見出し ---- */
.dock-flow-head { font-family:'Noto Serif JP',serif; text-align:center; font-size:clamp(1.4rem,3vw,1.9rem); font-weight:600; color:#3a342e; margin:4.5rem 0 0.4rem; }
.dock-flow-sub { text-align:center; font-size:0.92rem; color:#7a7064; margin:0 0 0.5rem; }

/* 予約への導線（なぜ定期的な検査が大切なの？の下） */
.dock-reserve-cta { text-align: center; margin: 3rem auto 0; }
.dock-reserve-lead { font-family: 'Noto Serif JP', serif; color: #6e6657; font-size: 1rem; line-height: 1.9; margin: 0 0 1.3rem; }
.dock-reserve-btn { position: relative; display: inline-flex; align-items: center; gap: 1.1rem; padding: 1.05rem 2.8rem; font-family: 'Noto Serif JP', serif; font-size: 1.08rem; font-weight: 600; color: #fff; text-decoration: none; background: linear-gradient(135deg,#92BC7E,#7FB06C); border-radius: 999px; box-shadow: 0 14px 30px rgba(120,170,100,0.32); transition: transform .25s, box-shadow .25s, filter .25s; }
.dock-reserve-btn:hover { transform: translateY(-3px); box-shadow: 0 20px 40px rgba(120,170,100,0.42); filter: brightness(1.04); }
.dock-reserve-btn .snav-sp-wrap { position: absolute; inset: 0; pointer-events: none; }
.dock-reserve-arr { font-family: 'Cormorant Garamond', serif; font-size: 1.35rem; }
