/* ============================================================
   丸山ファミリー歯科 — 共有スタイルシート
   トーン: 清潔・信頼(やわらかい青) × 家族の温かみ(コーラル)
   姉妹サイト(名古屋てんかん・こころクリニック)の設計知見を移植
   ============================================================ */

:root{
  /* 構造色(見出し・枠線・リンク・表頭) = 青で統一 */
  --blue:#2f6f9e;
  --blue-d:#255c83;          /* ホバー・一段濃く */
  --blue-deep:#1f4e6b;       /* 濃い帯・濃い見出し・フッター */

  /* 行動喚起・警告(予約ボタン・休診)= コーラルだけ */
  --coral:#e0795a;
  --coral-d:#c9633f;

  /* 面・補助 */
  --sky:#eaf1f5;             /* 淡い面(チップ・淡い帯) */
  --sky-2:#dbe6ee;
  --bg:#fcfaf7;              /* 温かいオフホワイト(脱・青み白) */
  --bg-light:#f4f0e9;        /* セクション交互=ウォームグレージュ */
  --ink:#2c3a42;             /* 本文(落ち着いた墨) */
  --gray:#6e655c;            /* サブ=ウォームグレー */
  --line:#e8e1d6;            /* 罫線=ウォームヘアライン */
  --white:#fff;

  /* タイポ: 見出し=明朝(上品)/ 英字=Cormorant(洗練) */
  --serif:"Noto Serif JP","Hiragino Mincho ProN","Yu Mincho",serif;
  --display:"Cormorant Garamond","Noto Serif JP",serif;

  --radius:10px;
  --shadow:0 6px 26px rgba(54,44,32,.06);
  --maxw:1120px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:84px;overflow-x:clip}
body{
  font-family:"Noto Sans JP","Hiragino Sans","Hiragino Kaku Gothic ProN","Meiryo",system-ui,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.95;
  -webkit-font-smoothing:antialiased;letter-spacing:.02em;text-rendering:optimizeLegibility;
  overflow-x:clip;
}
img{max-width:100%;display:block}
a{color:var(--blue-d);text-decoration:none}
a:hover{text-decoration:underline}
a:focus-visible,button:focus-visible,summary:focus-visible{outline:3px solid var(--coral);outline-offset:2px;border-radius:6px}
strong{font-weight:700;color:inherit}

/* 見出しは明朝(上品・脱AI)。英字キッカーはCormorant */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;letter-spacing:.04em;line-height:1.55}

/* ---- ヘッダー(上段=ロゴ＋住所/電話/予約、下段=ナビ) ---- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(252,250,247,.88);
  backdrop-filter:blur(12px) saturate(1.1);border-bottom:1px solid var(--line);
}
.head-main{
  max-width:var(--maxw);margin:0 auto;padding:1rem 1.4rem .35rem;
  display:flex;align-items:center;gap:1.1rem;
}
.brand{display:flex;align-items:center;gap:.95rem;flex:none;text-decoration:none!important}
.brand .mark{height:74px;width:auto;display:block;flex:none}
.brand .wordmark{display:flex;flex-direction:column;line-height:1.18;gap:.18rem}
.brand .wm-name{font-family:var(--serif);font-size:2.05rem;font-weight:600;color:var(--blue-deep);letter-spacing:.14em}
.brand .wm-en{font-family:var(--display);font-size:.78rem;font-weight:600;color:var(--gray);letter-spacing:.34em;text-transform:uppercase}

.head-right{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:.4rem}
.head-right .addr{color:var(--gray);font-size:.84rem;font-weight:600}
.addr-access{color:var(--blue-d);font-weight:800}
.head-actions{display:flex;align-items:center;gap:.9rem}
.head-tel{display:flex;flex-direction:column;line-height:1.1;text-decoration:none!important;align-items:flex-start}
.head-tel .lbl{font-size:.66rem;color:var(--gray);font-weight:700}
.head-tel .num{font-size:1.5rem;font-weight:800;color:var(--blue-deep);letter-spacing:.01em}

.btn-book{
  display:inline-flex;align-items:center;gap:.4rem;background:var(--coral);color:#fff!important;
  font-weight:600;font-size:.98rem;letter-spacing:.04em;padding:.8rem 1.5rem;border-radius:6px;text-decoration:none!important;
  transition:background .2s,box-shadow .2s;white-space:nowrap;box-shadow:0 6px 18px rgba(224,121,90,.22);
}
.btn-book:hover{background:var(--coral-d)}

/* 下段:ナビ */
.nav{max-width:var(--maxw);margin:0 auto;padding:.2rem 1.4rem .7rem}
.nav ul{list-style:none;display:flex;gap:2rem;flex-wrap:wrap;align-items:center;justify-content:center}
.nav a{color:var(--ink);font-weight:500;font-size:1rem;padding:.35rem .2rem;position:relative;letter-spacing:.08em}
.nav a:hover{color:var(--blue);text-decoration:none}
.nav a.current{color:var(--blue);font-weight:700}
.nav a.current::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:3px;
  background:var(--coral);border-radius:3px;
}
.nav a.navhome{background:var(--sky);color:var(--blue-d);border-radius:7px;padding:.4rem 1.2rem;font-weight:800}
.nav a.navhome:hover{background:var(--sky-2);color:var(--blue-d)}
.nav a.navhome.current{background:var(--sky);color:var(--blue-d)}
.nav a.navhome.current::after{display:none}
.nav-toggle{display:none}

/* ヘッダー Instagram アイコン */
.head-insta{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:10px;background:linear-gradient(45deg,#833ab4,#e1306c,#fcb045);border:none;color:#fff;flex:none;transition:opacity .2s}
.head-insta:hover{opacity:.85;text-decoration:none}
.head-insta svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
@media(max-width:860px){.head-insta{display:none}}
/* Instagram リンク共通スタイル */
.insta-btn{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(45deg,#833ab4,#e1306c,#fcb045);color:#fff!important;padding:.55rem 1.1rem;border-radius:7px;font-weight:700;font-size:.92rem;text-decoration:none!important;transition:opacity .2s}
.insta-btn:hover{opacity:.85;text-decoration:none!important}
.insta-btn svg{stroke:#fff}

/* ---- モバイル用 所在地バー(ヘッダー直下・場所をすぐ表示) ---- */
.loc-bar{display:none}
@media(max-width:980px){
  .loc-bar{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap;
    background:var(--sky);border-bottom:1px solid var(--sky-2);padding:.55rem .9rem;
    font-size:.82rem;color:var(--ink);text-decoration:none!important;line-height:1.5}
  .loc-bar svg{width:15px;height:15px;stroke:var(--blue);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex:none}
  .loc-bar .map{color:var(--blue-d);font-weight:800;white-space:nowrap}
}

/* ---- 費用の目安テーブル ---- */
.price-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);margin:1.4rem 0 .6rem}
.price-table th,.price-table td{border:1px solid var(--line);padding:.7rem .9rem;font-size:.92rem;text-align:left;vertical-align:middle}
.price-table thead th{background:var(--blue);color:#fff;font-weight:700;text-align:center}
.price-table td.kbn{text-align:center;white-space:nowrap;font-weight:700}
.price-table td.kbn .b-hoken{display:inline-block;background:var(--sky);color:var(--blue-d);border-radius:5px;padding:.1rem .5rem;font-size:.78rem}
.price-table td.kbn .b-jihi{display:inline-block;background:#fff0ea;color:var(--coral-d);border-radius:5px;padding:.1rem .5rem;font-size:.78rem}
.price-table td.fee{text-align:right;white-space:nowrap;font-weight:700;color:var(--blue-deep)}
.price-table tbody tr:nth-child(even){background:var(--bg-light)}
@media(max-width:560px){.price-table th,.price-table td{font-size:.82rem;padding:.5rem .55rem}}

/* ---- ボタン ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;background:var(--coral);color:#fff!important;
  padding:.95rem 2rem;border-radius:6px;font-weight:600;letter-spacing:.06em;
  transition:background .2s,box-shadow .2s,transform .15s;text-decoration:none!important;
  box-shadow:0 6px 18px rgba(224,121,90,.22);
}
.btn:hover{background:var(--coral-d);box-shadow:0 8px 22px rgba(224,121,90,.3)}
.btn.ghost{background:transparent;color:var(--blue-d)!important;border:1px solid var(--blue);box-shadow:none}
.btn.ghost:hover{background:var(--sky);box-shadow:none}

/* ---- 初めての方へ導線 ---- */
.first-visit{display:flex;align-items:center;gap:1.2rem;padding:.95rem 0;text-decoration:none!important;color:inherit}
.first-visit:hover .fv-title{color:var(--blue)}
.fv-ico{width:50px;height:50px;border-radius:50%;background:#fff;border:1.5px solid #b8d4e4;display:grid;place-items:center;color:var(--blue-d);flex:none}
.fv-body{flex:1;display:flex;flex-direction:column;gap:.12rem}
.fv-title{font-family:var(--serif);font-size:1.1rem;font-weight:600;color:var(--blue-deep)}
.fv-desc{font-size:.84rem;color:var(--gray)}
.fv-arrow{font-size:.88rem;font-weight:700;color:var(--blue-d);white-space:nowrap}
@media(max-width:480px){.fv-desc{display:none}}

/* ---- レイアウト ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.4rem}
.wrap-narrow{max-width:820px}
section{padding:6rem 0}
section.tight{padding:3.4rem 0}
.alt{background:var(--bg-light)}
.section-title{font-size:2.05rem;color:var(--blue-deep);font-weight:600;margin-bottom:.7rem;text-align:center;line-height:1.5;letter-spacing:.06em}
.section-lead{color:var(--gray);text-align:center;margin-bottom:3.2rem;font-size:1rem;line-height:2;text-wrap:balance;word-break:auto-phrase}
.section-lead span,.page-hero p span{display:inline-block}
/* キッカー: 細い罫線つきの英字ラベル(視線の起点) */
.kicker{font-family:var(--display);color:var(--coral-d);font-weight:600;letter-spacing:.3em;text-align:center;font-size:.92rem;text-transform:uppercase;margin-bottom:.7rem;display:flex;align-items:center;justify-content:center;gap:.9rem}
.kicker::before,.kicker::after{content:"";width:28px;height:1px;background:var(--coral);opacity:.5}

/* ---- ヒーロー(外観写真 全背景 + 暗グラデoverlay) ---- */
.hero{
  position:relative;overflow:hidden;
  background:
    linear-gradient(100deg, rgba(13,32,46,.96) 0%, rgba(13,32,46,.90) 42%, rgba(13,32,46,.60) 72%, rgba(13,32,46,.34) 100%),
    url("../images/exterior-main.jpg") center/cover no-repeat;
  padding:5.2rem 0 4.6rem;
}
.hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:2.4rem;align-items:center}
.hero-copy{max-width:620px}
.hero .catch{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--display);color:#f7c9b6;font-weight:600;font-size:1.05rem;margin-bottom:.55rem;letter-spacing:.22em;text-transform:uppercase}
.hero .catch::before{content:"";width:34px;height:1px;background:#f7c9b6;opacity:.7}
.hero-name{font-family:var(--serif);color:#fff;font-size:2.3rem;font-weight:700;letter-spacing:.12em;margin-bottom:.7rem;text-shadow:0 2px 14px rgba(0,0,0,.55),0 1px 3px rgba(0,0,0,.5)}
.hero h1{font-family:var(--serif);font-size:2.6rem;color:#fff;line-height:1.55;margin-bottom:1.2rem;font-weight:600;letter-spacing:.06em;text-shadow:0 2px 16px rgba(0,0,0,.55),0 1px 3px rgba(0,0,0,.5)}
.hero h1 .accent{color:#b6e2f4}
.hero p.lead-p{font-size:1.08rem;color:#fff;margin-bottom:1.6rem;line-height:2;text-shadow:0 1px 8px rgba(0,0,0,.5)}
.hero p.lead-p span{display:inline-block}
.hero-mark{display:flex;justify-content:center;align-items:center}
.hero-mark img{width:100%;max-width:340px;height:auto}
/* ヒーローの事実バッジ */
.hero-facts{list-style:none;margin:1.4rem 0 1.8rem;display:grid;gap:.8rem;max-width:560px}
.hero-facts li{position:relative;padding-left:5em;font-size:.95rem;color:#fff;line-height:1.6;font-weight:600;text-shadow:0 1px 6px rgba(0,0,0,.45)}
.hero-facts b{position:absolute;left:0;top:.15rem;font-size:.72rem;font-weight:800;color:#fff;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:.12rem .55rem;letter-spacing:.05em}
.hero-facts .fact-access strong{color:#fff;font-size:1.02rem}
.hero-facts a{color:#fff;text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(255,255,255,.85);text-decoration-thickness:1.5px;transition:text-decoration-color .2s,text-underline-offset .2s}
.hero-facts a:hover{text-decoration-color:#fff;text-underline-offset:4px}
.hero-facts a.fact-more{margin-left:.7rem;font-size:.78rem;font-weight:700;color:#f3a98e;text-decoration:none;white-space:nowrap}
.hero-facts a.fact-more:hover{text-decoration:none;color:#f8c2ad}
.hero .cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:.4rem}
/* ヒーロー上のゴーストボタンは白抜き */
.hero .btn.ghost{background:#fff;border-color:#fff;color:var(--blue-deep)!important}
.hero .btn.ghost:hover{background:rgba(255,255,255,.9);text-decoration:none}
@media(max-width:860px){
  .hero{
    background:
      linear-gradient(180deg, rgba(13,32,46,.9) 0%, rgba(13,32,46,.84) 100%),
      url("../images/exterior-main.jpg") center/cover no-repeat;
  }
}

/* ---- スマホ用 追従予約バー ---- */
.mobile-cta{display:none}

/* ---- トップ最上部:診療時間(表)＋お知らせ ---- */
.topinfo{padding:2.4rem 0 3.2rem}
.topinfo .wrap{display:grid;grid-template-columns:1.25fr .9fr;gap:1.4rem;align-items:start}
.hours-block{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--line);padding:1.6rem 1.8rem}
.ti-head{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap;margin-bottom:.9rem}
.ti-title{color:var(--blue-deep);font-size:1.35rem;font-weight:600;letter-spacing:.04em}
.ti-badge{display:inline-flex;align-items:center;gap:.35rem;background:var(--coral);color:#fff;font-weight:800;font-size:.92rem;border-radius:8px;padding:.4rem .9rem;white-space:nowrap}
.ti-badge svg{width:1.05em;height:1.05em;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ti-note{margin-top:.8rem;font-size:.9rem;color:#6b4a40;background:#fff6f3;border:1px solid #f3d3c9;border-radius:10px;padding:.6rem .9rem}
.ti-note strong{color:var(--coral-d)}

/* ---- テーブル(診療時間) ---- */
.timetable{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);table-layout:fixed}
.timetable th,.timetable td{border:1px solid var(--line);padding:.7rem;text-align:center;font-size:.92rem}
.timetable thead th{background:var(--blue);color:#fff;font-weight:700}
.timetable td.on{color:var(--coral-d);font-weight:800}
.timetable td.off{color:#b7c6d1}
.timetable td:first-child{text-align:left;white-space:nowrap;font-weight:700;color:var(--blue-deep);background:#deeaf4}
/* 日ごとの診療時間表(午前・午後を文字で) */
.hours-table td{font-weight:600;color:var(--ink)}
.hours-table tr.rest td,.hours-table tr.rest td:first-child{color:var(--coral-d);font-weight:700;background:#fff6f3}
.hours-table .through{color:var(--blue-d);font-weight:700}

/* ---- お知らせ ---- */
.news-box{background:#fff;border:1px solid var(--line);border-left:3px solid var(--coral);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.3rem 1.5rem}
.news-head{display:flex;align-items:center;gap:.6rem;margin-bottom:.8rem}
.news-head h2,.news-head h3{color:var(--blue-deep);font-size:1.25rem;font-weight:600;letter-spacing:.04em}
.news-ico{width:22px;height:22px;color:var(--coral-d);flex:none}
.news-ico svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linejoin:round;stroke-linecap:round}
.news-list{list-style:none;display:grid;gap:.2rem}
.news-list li{display:grid;grid-template-columns:1fr;gap:.15rem;padding:.55rem 0;border-top:1px dashed var(--line)}
.news-list li:first-child{border-top:none}
.news-list .nl-top{display:flex;align-items:center;gap:.6rem;margin-bottom:.25rem;flex-wrap:wrap}
.news-list time{display:inline-flex;align-items:center;gap:.4rem;color:var(--gray);font-size:.82rem;font-weight:700}
.news-list .nl-lbl{font-size:.66rem;font-weight:700;color:var(--gray);background:var(--bg-light);border:1px solid var(--line);border-radius:4px;padding:.05rem .4rem}
.news-tag{justify-self:start;font-size:.72rem;font-weight:800;color:#fff;border-radius:4px;padding:.16rem .7rem;white-space:nowrap;line-height:1.6}
.tag-rest{background:var(--coral-d)}
.tag-info{background:var(--blue)}
.news-list p{color:#3f525d;font-size:.93rem;line-height:1.75}
.news-insta{color:var(--gray);font-size:.86rem;line-height:1.8;margin-top:.6rem}
.news-insta a{font-weight:700}
#news-list:not(:empty) + .news-insta{margin-top:.9rem;padding-top:.8rem;border-top:1px dashed var(--line)}
.news-note{color:var(--gray);font-size:.8rem}

/* ---- 特長・診療メニューカード ---- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem}
.cards.cols-3{grid-template-columns:repeat(3,1fr)}
.card{
  background:#fff;border-radius:var(--radius);box-shadow:none;
  padding:2.2rem 1.7rem;border:1px solid var(--line);
  transition:border-color .25s ease,box-shadow .25s ease;
}
.card:hover{border-color:var(--sky-2);box-shadow:var(--shadow)}
/* アイコン: 細線・円の中・上品 */
.card .ico{width:54px;height:54px;margin:0 0 1.1rem;color:var(--blue);display:grid;place-items:center;border:1px solid var(--sky-2);border-radius:50%}
.card .ico svg{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}
.card h3{color:var(--blue-deep);font-size:1.2rem;font-weight:600;margin:.2rem 0 .6rem;letter-spacing:.03em}
.card p{color:var(--gray);font-size:.92rem;line-height:1.9}
.card p a{font-weight:700;color:var(--blue-d)}
.card p a:hover{color:var(--blue);text-decoration:none}

/* ---- 診療メニュー: 上半分が写真のカード ---- */
.menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem}
.menu-card{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;text-decoration:none!important;color:inherit;transition:box-shadow .25s ease,border-color .25s ease,transform .25s ease}
.menu-card:hover{box-shadow:var(--shadow);border-color:var(--sky-2);transform:translateY(-3px)}
.menu-photo{aspect-ratio:1/1;overflow:hidden;background:var(--bg-light)}
.menu-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.menu-card:hover .menu-photo img{transform:scale(1.05)}
.menu-body{padding:1.3rem 1.4rem 1.5rem}
.menu-body h3{display:flex;align-items:baseline;gap:.5rem;color:var(--blue-deep);font-size:1.2rem;font-weight:600;letter-spacing:.04em;margin-bottom:.5rem}
.menu-body h3 .en{font-family:var(--display);font-size:.78rem;font-weight:600;color:var(--coral-d);letter-spacing:.12em;text-transform:uppercase}
.menu-body p{color:var(--gray);font-size:.9rem;line-height:1.85}
.menu-more{display:inline-block;margin-top:.8rem;color:var(--blue-d);font-weight:600;font-size:.86rem;letter-spacing:.04em}
.menu-card:hover .menu-more{color:var(--blue)}
@media(max-width:860px){.menu-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.menu-grid{grid-template-columns:1fr}}

/* ---- 施設紹介ギャラリー ---- */
.fac-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.fac-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:box-shadow .25s ease,border-color .25s ease}
.fac-card:hover{box-shadow:var(--shadow);border-color:var(--sky-2)}
.fac-photo{aspect-ratio:4/3;overflow:hidden;background:var(--bg-light)}
.fac-photo img{width:100%;height:100%;object-fit:cover;display:block}
.fac-ph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.55rem;background:var(--sky);color:var(--blue-d)}
.fac-ph svg{width:46px;height:46px;stroke:currentColor;fill:none;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}
.fac-ph span{font-size:.8rem;font-weight:700;color:var(--gray);letter-spacing:.04em}
.fac-body{padding:1.2rem 1.35rem 1.45rem}
.fac-body h3{display:flex;align-items:center;gap:.6rem;color:var(--blue-deep);font-size:1.14rem;font-weight:600;margin-bottom:.45rem;letter-spacing:.03em}
.fac-body .badge{font-size:.72rem;font-weight:700;color:#fff;background:var(--coral);border-radius:5px;padding:.12rem .55rem;letter-spacing:.03em;white-space:nowrap}
.fac-body p{color:var(--gray);font-size:.9rem;line-height:1.85}
@media(max-width:860px){.fac-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.fac-grid{grid-template-columns:1fr}}

/* ---- 院長の肉声(挨拶) ---- */
.voice{position:relative;max-width:780px;margin:0 auto;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1.8rem 2rem;border-left:4px solid var(--coral)}
.voice p{font-size:1.04rem;color:#3f525d;line-height:2.05}
.voice .sign{text-align:right;color:var(--blue-deep);font-family:var(--serif);font-weight:600;letter-spacing:.06em;margin-top:1rem}

/* ---- 2カラム情報 / パネル ---- */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.8rem}
.panel{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1.7rem;border:1px solid var(--line)}
.panel h3{color:var(--blue-deep);margin-bottom:.9rem;font-size:1.22rem;font-weight:600;padding-left:.8rem;border-left:3px solid var(--blue);letter-spacing:.03em}
.panel ul{margin-left:1.1rem;color:#3f525d}
.panel li{margin:.45rem 0}
.panel li a{font-weight:700;text-decoration:underline}
.panel li a:hover{color:var(--blue)}

/* ---- 注意/補足ボックス ---- */
.notice{background:#fff6f3;border:1px solid #f3d3c9;border-left:6px solid var(--coral);border-radius:14px;padding:1.2rem 1.4rem}
.notice h3{color:var(--coral-d);margin-bottom:.5rem;font-size:1.05rem}
.notice p,.notice li{font-size:.93rem;color:#6b4a40}
.notice strong{color:var(--coral-d)}

/* ---- ステップ(初診の流れなど) ---- */
.steps{counter-reset:step;display:grid;gap:1rem}
.step{background:#fff;border-radius:12px;box-shadow:var(--shadow);padding:1.2rem 1.4rem 1.2rem 3.6rem;position:relative;border:1px solid var(--line)}
.step::before{counter-increment:step;content:counter(step);position:absolute;left:1rem;top:1.1rem;width:36px;height:36px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;font-weight:700}
.step h3{color:var(--blue-deep);font-size:1.05rem;margin-bottom:.2rem}
.step p{color:#4a5860;font-size:.92rem}

/* ---- ページヘッダー(下層ページ) ---- */
.page-hero{position:relative;text-align:center;padding:2.4rem 0 1.8rem;background:linear-gradient(180deg,#efe9df,var(--bg));border-bottom:1px solid var(--line)}
.page-hero h1{color:var(--blue-deep);font-size:1.95rem;margin-bottom:.4rem}
.page-hero p{color:#3f525d;font-size:1.08rem;line-height:1.9;max-width:700px;margin:0 auto;font-weight:500;text-wrap:balance;word-break:auto-phrase}

/* ---- 院長挨拶(ホーム) ---- */
.doctor-intro{display:grid;grid-template-columns:200px 1fr;gap:2rem;align-items:start;max-width:860px;margin:0 auto}
.doctor-intro .photo{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:3/4}
.doctor-intro .photo img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:680px){
  .doctor-intro{grid-template-columns:1fr}
  .doctor-intro .photo{aspect-ratio:4/3}
}

/* ---- 設備カード(写真+テキスト) ---- */
.equip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.equip-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--line);overflow:hidden;transition:border-color .18s,box-shadow .18s}
.equip-card:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(31,78,107,.1)}
.equip-card .ph{height:180px;overflow:hidden;background:#fff;border-bottom:1px solid var(--line)}
.equip-card .ph img{width:100%;height:100%;object-fit:contain;padding:.7rem;display:block}
.equip-card .tx{padding:1rem 1.2rem}
.equip-card .tx h3{color:var(--blue-deep);font-size:1rem;margin-bottom:.35rem;font-weight:800}
.equip-card .tx p{color:#4a5860;font-size:.9rem}
@media(max-width:860px){.equip-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.equip-grid{grid-template-columns:1fr}}

/* ---- 治療写真行 ---- */
.tx-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin-top:1.4rem}
.tx-photo{border-radius:10px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.tx-photo img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.tx-photo figcaption{font-size:.78rem;font-weight:700;color:var(--gray);padding:.5rem .7rem;background:#fff;text-align:center}
@media(max-width:680px){.tx-photos{grid-template-columns:1fr 1fr}}

/* ---- スタッフプロフィール ---- */
.profile-grid{display:grid;grid-template-columns:220px 1fr;gap:2rem;align-items:start;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem;border:1px solid var(--line)}
.profile-grid + .profile-grid{margin-top:1.4rem}
.avatar{width:220px;aspect-ratio:1/1;border-radius:var(--radius);background:var(--sky);display:grid;place-items:center;color:var(--blue-d);font-size:3rem;overflow:hidden;border:1px solid var(--line);flex:none}
.avatar img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.avatar-ph{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--blue-d)}
.avatar-ph svg{width:56px;height:56px;stroke:currentColor;fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.avatar-ph span{font-size:.78rem;font-weight:700;color:var(--gray)}
.profile-body h2{color:var(--blue-deep);font-size:1.7rem;font-weight:600;letter-spacing:.05em;margin-bottom:.25rem}
.profile-body h2 .post{display:inline-block;vertical-align:middle;background:var(--blue-deep);color:#fff;font-size:.8rem;font-weight:700;letter-spacing:.08em;padding:.22rem .7rem;border-radius:6px;margin-right:.7rem;transform:translateY(-.14em)}
.profile-body h2 .kana{font-size:.8em;font-weight:500;color:var(--gray);margin-left:.3rem;letter-spacing:.04em}
.profile-body .role-sub{color:var(--gray);font-weight:600;font-size:.95rem;letter-spacing:.06em;margin-bottom:.95rem}
.profile-body .role{color:var(--blue-d);font-weight:700;margin-bottom:.3rem;font-size:1rem;letter-spacing:.04em}
.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.8rem}
.chip{background:#efe9df;border-radius:6px;padding:.4rem .95rem;font-size:.85rem;color:var(--blue-d);font-weight:600;letter-spacing:.03em}
.timeline{list-style:none;border-left:3px solid var(--sky-2);margin-left:.3rem;padding-left:1.2rem;margin-top:.6rem}
.timeline li{position:relative;margin:.55rem 0;font-size:.94rem;color:#3f525d}
.timeline li b{color:var(--blue-d);font-weight:700;margin-right:.35rem}
.timeline li::before{content:"";position:absolute;left:-1.55rem;top:.55rem;width:10px;height:10px;border-radius:50%;background:var(--coral);box-shadow:0 0 0 3px var(--sky)}
@media(max-width:680px){
  .profile-grid{grid-template-columns:1fr}
  .avatar{width:100%;max-width:300px;margin:0 auto;aspect-ratio:1/1;height:auto}
}

/* ---- 地図プレースホルダー・アクセス ---- */
.map-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:var(--bg-light);aspect-ratio:16/7;display:grid;place-items:center}
.map-wrap iframe{width:100%;height:100%;display:block;border:none}
.map-ph{display:flex;flex-direction:column;align-items:center;gap:.7rem;color:var(--gray)}
.map-ph svg{width:48px;height:48px;stroke:currentColor;fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.access-rows{display:grid;gap:1rem;margin-top:1.4rem}
.access-row{display:grid;grid-template-columns:5rem 1fr;gap:.6rem 1rem;align-items:start;padding:.85rem 1rem;background:#fff;border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:10px}
.access-row .lbl{font-size:.72rem;font-weight:800;color:#fff;background:var(--blue);border-radius:5px;padding:.15rem .55rem;text-align:center;height:fit-content}
.access-row .val{color:var(--ink);font-size:.96rem;line-height:1.75}
.access-row .val strong{color:var(--blue-deep)}

/* ---- ブログ一覧 ---- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.blog-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--line);overflow:hidden;transition:border-color .18s ease,box-shadow .18s ease}
.blog-card:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(31,78,107,.1)}
.blog-card a{text-decoration:none!important;color:inherit;display:block}
.blog-thumb{height:160px;background:var(--sky);display:grid;place-items:center;color:var(--blue-d);overflow:hidden}
.blog-thumb img{width:100%;height:100%;object-fit:cover}
.blog-thumb-ph{display:flex;flex-direction:column;align-items:center;gap:.4rem}
.blog-thumb-ph svg{width:38px;height:38px;stroke:currentColor;fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.blog-body{padding:1.1rem 1.2rem}
.blog-meta{display:flex;align-items:center;gap:.6rem;margin-bottom:.5rem}
.blog-meta time{font-size:.78rem;color:var(--gray);font-weight:700}
.blog-tag{font-size:.7rem;font-weight:800;color:#fff;background:var(--blue);border-radius:5px;padding:.1rem .55rem}
.blog-card h3{color:var(--blue-deep);font-size:1rem;font-weight:800;line-height:1.55;margin-bottom:.4rem}
.blog-card p{color:#4a5860;font-size:.88rem;line-height:1.75}
@media(max-width:860px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.blog-grid{grid-template-columns:1fr}}

/* ブログ: 年リンク(左・縦) + 記事(右) のレイアウト */
.blog-layout{display:flex;gap:2.5rem;align-items:flex-start;max-width:920px;margin:0 auto}
.blog-year-nav{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;flex:none;width:96px;position:sticky;top:96px}
.blog-year-btn{
  background:transparent;border:0;border-left:2px solid transparent;
  color:var(--blue-d);cursor:pointer;font-family:"Noto Sans JP",sans-serif;
  font-size:.95rem;font-weight:600;padding:.3rem .9rem;text-align:left;
  transition:color .15s,border-color .15s;
}
.blog-year-btn:hover{color:var(--blue);text-decoration:underline;text-underline-offset:3px}
.blog-year-btn.active{color:var(--blue-deep);border-left-color:var(--coral);font-weight:700}

/* ブログ記事アコーディオン */
.blog-post-list{flex:1;min-width:0;max-width:760px}
.blog-post{background:#fff;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:.85rem;overflow:hidden}
.blog-post-header{
  display:flex;align-items:center;gap:.9rem;
  padding:1rem 1.2rem;cursor:pointer;
}
.blog-post-text{flex:1;min-width:0}
.blog-post-thumb{flex:none;width:60px;height:60px;object-fit:cover;border-radius:8px;border:1px solid var(--line);background:#fff}
.blog-post-header:hover .blog-post-title{color:var(--blue)}
.blog-post-meta{display:flex;align-items:baseline;gap:.8rem;margin-bottom:.3rem}
.blog-post-date{font-size:.78rem;color:var(--gray);font-weight:700;letter-spacing:.05em;white-space:nowrap}
.blog-post-title{font-family:var(--serif);font-size:1.08rem;font-weight:600;color:var(--blue-deep);line-height:1.55;margin:0}
.blog-post-excerpt{font-size:.84rem;color:var(--gray);line-height:1.7;margin-top:.3rem}
.blog-post-arrow{width:28px;height:28px;display:grid;place-items:center;border:1px solid var(--line);border-radius:50%;color:var(--blue-d);flex:none;transition:transform .2s,background .2s}
.blog-post.open .blog-post-arrow{transform:rotate(180deg);background:var(--sky)}
.blog-post-body{
  display:none;padding:0 1.2rem 1.2rem;border-top:1px solid var(--line);
}
.blog-post.open .blog-post-body{display:block}
/* 画像は記事末尾・面積を約半分に(横幅70%≒面積1/2)。左寄せ */
.blog-post-body figure{margin:1.4rem 0 .3rem;max-width:70%;border-radius:8px;overflow:hidden;border:1px solid var(--line)}
.blog-post-body figure img{display:block;width:100%;height:auto}
.blog-post-body p{font-size:.95rem;line-height:2;color:var(--ink);margin:.9rem 0 0}
.blog-post-body p:first-child{margin-top:.9rem}
.blog-post-loading{text-align:center;color:var(--gray);padding:2.5rem 0;font-size:.95rem}
@media(max-width:720px){
  .blog-layout{flex-direction:column;gap:1rem}
  .blog-year-nav{width:auto;position:static;flex-direction:row;flex-wrap:wrap;gap:.2rem 1.1rem;margin-bottom:.3rem}
  .blog-post-body figure{max-width:100%}
}

/* ---- ページ内目次(情報量の多いページの先頭) ---- */
.toc{max-width:var(--maxw);margin:2rem auto 0;padding:0 1.4rem}
.toc-inner{background:#fff;border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:12px;padding:1.1rem 1.4rem}
.toc-label{display:block;font-size:.78rem;font-weight:800;color:var(--blue-d);letter-spacing:.06em;margin-bottom:.7rem}
.toc ul{list-style:none;display:flex;flex-wrap:wrap;gap:.55rem .6rem;margin:0;padding:0}
.toc a{display:inline-block;font-size:.9rem;font-weight:700;color:var(--blue-d);background:var(--sky);border-radius:7px;padding:.42rem .95rem;text-decoration:none;transition:background .2s}
.toc a:hover{background:var(--sky-2);text-decoration:none}
.toc a::before{content:"#";opacity:.45;margin-right:.2em;font-weight:800}

/* ---- 導入リード(ページ冒頭の対象説明など) ---- */
.lead-box{background:#fff;border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:12px;padding:1.4rem 1.6rem}
.lead-box h3{color:var(--blue-deep);margin-bottom:.5rem;font-size:1.12rem}
.lead-box p{font-size:1.02rem;line-height:2;color:var(--ink)}

/* ---- サービス見出し(アンカー付きセクション) ---- */
.svc-block{margin-bottom:.5rem}
.svc-block .svc-name{display:flex;align-items:center;gap:.7rem;justify-content:center;margin-bottom:.4rem}
.svc-block .svc-name .ico{width:34px;height:34px;color:var(--blue);flex:none}
.svc-block .svc-name .ico svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
/* 写真+本文の左右レイアウト(エディトリアル) */
.svc-split{display:grid;grid-template-columns:.92fr 1.08fr;gap:2.6rem;align-items:center;max-width:980px;margin:0 auto}
.svc-split .svc-photo{margin:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3}
.svc-split .svc-photo img{width:100%;height:100%;object-fit:cover;display:block}
.svc-split .svc-text h3{color:var(--blue-deep);font-size:1.18rem;font-weight:600;margin-bottom:.6rem;letter-spacing:.03em;padding-left:.8rem;border-left:3px solid var(--blue)}
.svc-split .svc-text h3.mt{margin-top:1.7rem}
.svc-split .svc-text ul{list-style:none;margin:0}
.svc-split .svc-text li{position:relative;padding-left:1.3rem;margin:.45rem 0;color:#4a5860;font-size:.95rem;line-height:1.85}
.svc-split .svc-text li::before{content:"";position:absolute;left:0;top:.7em;width:6px;height:6px;border-radius:50%;background:var(--coral)}
@media(max-width:780px){.svc-split{grid-template-columns:1fr;gap:1.5rem}}

/* ---- 予約をうながすCTA帯(各ページ末尾) ---- */
.cta-band{background:var(--blue-deep);color:#fff;text-align:center}
.cta-band h2{color:#fff;font-size:1.85rem;font-weight:600;letter-spacing:.06em;margin-bottom:.6rem}
.cta-band p{color:#cfe0ec;margin-bottom:1.4rem}
.cta-band .cta-tel{display:block;font-size:1.9rem;font-weight:800;color:#fff;letter-spacing:.02em;margin-bottom:.3rem}
.cta-band .cta-tel:hover{text-decoration:none}
.cta-band .btn{background:#fff;color:var(--blue-d)!important}
.cta-band .btn:hover{background:var(--sky)}
.cta-band .sub{display:block;margin-top:.9rem;font-size:.85rem;color:#bcd2e3}
/* CTA帯: 左=お支払い方法 / 右=ご予約(2カラム) */
.cta-band-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center;text-align:left}
/* 右=お支払い方法(縦並び・大きめ) */
.cta-pay{border-left:1px solid rgba(255,255,255,.2);padding-left:3rem}
.cta-pay h3{color:#fff;font-size:1.3rem;font-weight:600;letter-spacing:.05em;margin-bottom:.5rem}
.cta-pay > p{color:#cfe0ec;font-size:.92rem;margin-bottom:1.1rem}
.pay-imgs{display:flex;flex-direction:column;gap:.8rem;margin-bottom:.9rem;align-items:flex-start}
.pay-imgs img{width:100%;max-width:340px;height:auto;background:#fff;border-radius:8px;padding:.55rem .7rem;border:1px solid rgba(255,255,255,.25)}
.pay-note{color:#bcd2e3;font-size:.86rem;line-height:1.7}
/* 左=ご予約 */
.cta-main{text-align:center}
.cta-main h2{color:#fff;font-size:1.85rem;font-weight:600;letter-spacing:.06em;margin-bottom:.5rem}
.cta-main > p{color:#cfe0ec;margin-bottom:1rem}
@media(max-width:780px){
  .cta-band-grid{grid-template-columns:1fr;gap:2rem;text-align:center}
  .cta-pay{border-left:none;border-top:1px solid rgba(255,255,255,.2);padding-left:0;padding-top:2rem}
  .pay-imgs{align-items:center}
  .pay-imgs img{max-width:300px}
}

/* ---- フッター ---- */
.site-footer{background:var(--blue-deep);color:#cdddea;padding:2.8rem 0 1.4rem;font-size:.9rem}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1.2fr;gap:1.6rem 2rem;margin-bottom:1.6rem}
.site-footer h4{color:#fff;margin-bottom:.8rem;font-size:1.05rem;font-weight:600;letter-spacing:.06em}
.site-footer a{color:#cdddea}
.site-footer a:hover{color:#fff}
.site-footer ul{list-style:none}
.site-footer li{margin:.3rem 0}
.site-footer .f-addr{font-size:.84rem;line-height:1.9;color:#bcd2e3}
.copy{text-align:center;border-top:1px solid rgba(255,255,255,.15);padding-top:1rem;color:#a9c2d6;font-size:.82rem}

/* ============================================================
   レスポンシブ
   ============================================================ */
@media(max-width:980px){
  .head-right .addr{display:none}
  .head-tel{display:none}
}
@media(max-width:860px){
  section{padding:3.6rem 0}
  .hero{padding:2.6rem 0 2.4rem}
  .hero .wrap{grid-template-columns:1fr;gap:1.4rem}
  .hero-copy{max-width:none;order:1}
  .hero-mark{order:2;margin-top:.6rem}
  .hero-mark img{max-width:280px}
  .hero h1{font-size:1.75rem}
  .hero-name{font-size:1.7rem}
  .topinfo .wrap{grid-template-columns:1fr}
  .cards,.cards.cols-3{grid-template-columns:1fr 1fr}
  .info-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}

  /* ヘッダー: ロゴ＋ハンバーガー */
  .head-main{padding:.5rem 1rem;gap:.6rem}
  .brand .mark{height:46px}
  .brand .wm-name{font-size:1.05rem}
  .brand .wm-en{display:none}
  .head-right{margin-left:auto}
  .btn-book{display:none}
  .nav-toggle{display:block;background:none;border:none;font-size:1.7rem;color:var(--blue-deep);cursor:pointer;line-height:1}
  .nav{position:relative;padding:0}
  .nav ul{
    display:none;position:absolute;top:0;left:0;right:0;background:#fff;z-index:60;
    flex-direction:column;align-items:stretch;gap:0;padding:.6rem 1.2rem;border-bottom:1px solid var(--line);box-shadow:var(--shadow)
  }
  .nav ul.open{display:flex}
  .nav li{padding:.2rem 0}
  .nav a.navhome{align-self:flex-start}
  .nav a.current::after{left:-1.2rem;right:auto;top:0;bottom:0;width:4px;height:auto}

  /* 追従予約バー */
  .mobile-cta{
    display:grid;grid-template-columns:1fr 1fr;gap:.55rem;
    position:fixed;left:0;right:0;bottom:0;z-index:90;
    padding:.5rem .7rem calc(.5rem + env(safe-area-inset-bottom));
    background:rgba(255,255,255,.97);backdrop-filter:blur(10px);
    border-top:1px solid var(--line);box-shadow:0 -6px 20px rgba(31,78,107,.12);
  }
  .mobile-cta a{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.85rem;border-radius:12px;font-weight:800;font-size:1rem;text-decoration:none!important}
  .mc-tel{background:#fff;color:var(--blue-d)!important;border:2px solid var(--blue)}
  .mc-web{background:var(--coral);color:#fff!important;box-shadow:0 4px 12px rgba(224,121,90,.35)}
  body{padding-bottom:4.8rem}
}
@media(max-width:560px){
  .cards,.cards.cols-3{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .ti-badge{font-size:.85rem;padding:.35rem .7rem}
  .hero-facts li{font-size:.8rem;padding-left:5.5em}
  .hero-facts b{font-size:.66rem}
  .hero-facts .fact-access strong{font-size:.88rem}
  .hero .catch{font-size:.88rem;letter-spacing:.05em}
  .hero .catch::before{width:18px}
  .access-row{grid-template-columns:3.2rem 1fr;padding:.75rem .85rem}
  .access-row .lbl{font-size:.7rem}
  .access-row .val{font-size:.88rem}
  .timetable th,.timetable td{padding:.5rem .35rem;font-size:.82rem}
}
