/* =========================================================
   むらまつクリニック サイト共通スタイル
   テーマ：やさしいグリーン系 / 清潔感・レスポンシブ対応
   ========================================================= */

:root {
  --c-primary:        #5cb589;
  --c-primary-dark:   #3f9268;
  --c-primary-darker: #2f7a53;
  --c-primary-light:  #eaf6f0;
  --c-primary-soft:   #d6ecdf;
  --c-accent:         #f4a259;
  --c-accent-soft:    #fdeede;
  --c-text:           #2f3e36;
  --c-muted:          #6b7d72;
  --c-line:           #e2ece6;
  --c-bg:             #f7faf8;
  --c-white:          #ffffff;
  --c-danger:         #e07a5f;
  --radius:           14px;
  --radius-sm:        9px;
  --shadow:           0 6px 22px rgba(47, 122, 83, 0.08);
  --shadow-lg:        0 14px 40px rgba(47, 122, 83, 0.14);
  --maxw:             1120px;
  --font: "Noto Sans JP", system-ui, -apple-system, "Hiragino Kaku Gothic ProN",
          "Yu Gothic", Meiryo, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; font-family: var(--font); color: var(--c-text);
  background: var(--c-bg); line-height: 1.8; font-size: 16px;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: var(--c-primary-dark); text-decoration: none; transition: color .2s; }
a:hover { color: var(--c-primary-darker); }
h1, h2, h3, h4 { line-height: 1.4; font-weight: 700; }
.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 20px; }
.section { padding: 64px 0; }
.section--tint { background: var(--c-primary-light); }
.section-head { text-align: center; margin-bottom: 40px; }
.section-head .en { display: block; color: var(--c-primary); font-weight: 700; letter-spacing: .15em; font-size: .8rem; margin-bottom: 6px; text-transform: uppercase; }
.section-head h2 { font-size: 1.7rem; margin: 0; }
.section-head p { color: var(--c-muted); margin: 10px 0 0; }

.btn { display: inline-flex; align-items: center; gap: 8px; background: var(--c-primary); color: #fff; font-weight: 700; padding: 13px 26px; border-radius: 999px; border: 2px solid var(--c-primary); cursor: pointer; transition: all .2s; font-size: .98rem; }
.btn:hover { background: var(--c-primary-dark); border-color: var(--c-primary-dark); color:#fff; transform: translateY(-2px); }
.btn--ghost { background: #fff; color: var(--c-primary-dark); }
.btn--ghost:hover { background: var(--c-primary-light); color: var(--c-primary-darker); }
.btn--accent { background: var(--c-accent); border-color: var(--c-accent); }
.btn--accent:hover { background: #e8924a; border-color: #e8924a; }

.site-header { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,.92); backdrop-filter: blur(8px); border-bottom: 1px solid var(--c-line); }
.header-inner { display: flex; align-items: center; justify-content: space-between; height: 74px; }
.brand { display: flex; align-items: center; gap: 12px; }
.brand .brand-logo { height: 46px; width: auto; max-height: 46px; display:block; }
.brand .brand-logo.is-mark { height: 44px; border-radius: 10px; }
.brand .brand-text strong { display: block; font-size: 1.12rem; line-height: 1.2; }
.brand .brand-text span { font-size: .72rem; color: var(--c-muted); letter-spacing: .08em; }
.header-right { display: flex; align-items: center; gap: 16px; }
.nav { display: flex; align-items: center; gap: 2px; }
.nav a { color: var(--c-text); font-weight: 500; padding: 10px 11px; border-radius: 8px; font-size: .92rem; white-space: nowrap; }
.nav a:hover, .nav a.is-active { background: var(--c-primary-light); color: var(--c-primary-darker); }

.header-actions { display: flex; align-items: center; gap: 10px; }
.h-tel { display: flex; align-items: center; gap: 9px; padding: 6px 14px 6px 12px; border-radius: 12px;
  background: var(--c-primary-light); color: var(--c-primary-darker); white-space: nowrap; }
.h-tel:hover { background: var(--c-primary-soft); color: var(--c-primary-darker); }
.h-tel .h-ico { font-size: 1.2rem; }
.h-tel .h-tel-text { display: flex; flex-direction: column; line-height: 1.1; }
.h-tel .h-tel-text small { font-size: .62rem; color: var(--c-muted); font-weight: 600; }
.h-tel .h-tel-text strong { font-size: 1.15rem; letter-spacing: .02em; font-variant-numeric: tabular-nums; }
.h-reserve { background: var(--c-accent); color: #fff; font-weight: 700; padding: 12px 18px; border-radius: 12px;
  white-space: nowrap; box-shadow: var(--shadow); }
.h-reserve:hover { background: #e8924a; color: #fff; transform: translateY(-1px); }
.nav-toggle { display: none; width: 46px; height: 46px; border: none; background: transparent; cursor: pointer; padding: 0; }
.nav-toggle span { display:block; width: 26px; height: 2.5px; margin: 5px auto; background: var(--c-text); border-radius:2px; transition: .3s; }
.nav-toggle.is-open span:nth-child(1){ transform: translateY(7.5px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2){ opacity: 0; }
.nav-toggle.is-open span:nth-child(3){ transform: translateY(-7.5px) rotate(-45deg); }

.hero { position: relative; overflow: hidden; background: linear-gradient(160deg, var(--c-primary-light) 0%, #ffffff 60%); }
.hero-inner { display: grid; grid-template-columns: 1.1fr .9fr; gap: 40px; align-items: center; padding: 70px 0; }
.hero .tagline { color: var(--c-primary-dark); font-weight: 700; letter-spacing:.05em; margin: 0 0 14px; }
.hero h1 { font-size: 2.4rem; margin: 0 0 18px; letter-spacing: .02em; }
.hero h1 .accent { color: var(--c-primary); }
.hero p.lead { font-size: 1.05rem; color: var(--c-muted); margin: 0 0 28px; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.hero-visual { border-radius: 20px; overflow: hidden; box-shadow: var(--shadow-lg); aspect-ratio: 16/9; background: var(--c-primary-light); display: grid; place-items: center; }
.hero-visual img { width: 100%; height: 100%; object-fit: cover; display:block; }
.hero-visual .hv-emoji { font-size: 4.5rem; }
.hero-visual .hv-text { font-weight: 700; letter-spacing:.1em; margin-top:8px; }

.quick-strip { background: var(--c-white); border-bottom: 1px solid var(--c-line); }
.quick-strip .container { display: grid; grid-template-columns: repeat(3,1fr); gap: 0; }
.quick-item { display:flex; gap:14px; align-items:center; padding: 22px 18px; }
.quick-item + .quick-item { border-left: 1px solid var(--c-line); }
.quick-item .qi-ico { font-size: 1.6rem; }
.quick-item .qi-label { font-size:.72rem; color:var(--c-muted); }
.quick-item .qi-value { font-weight: 700; font-size: 1.02rem; }

.cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.card { background: #fff; border: 1px solid var(--c-line); border-radius: var(--radius); padding: 30px 26px; box-shadow: var(--shadow); transition: transform .2s, box-shadow .2s; }
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.card .card-ico { width: 58px; height: 58px; border-radius: 16px; background: var(--c-primary-light); display: grid; place-items: center; font-size: 1.7rem; margin-bottom: 16px; }
.card h3 { margin: 0 0 8px; font-size: 1.18rem; }
.card p { margin: 0; color: var(--c-muted); font-size: .95rem; }

.hours-table { width: 100%; border-collapse: collapse; background:#fff; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.hours-table th, .hours-table td { padding: 14px 10px; text-align: center; border: 1px solid var(--c-line); font-size: .95rem; }
.hours-table thead th { background: var(--c-primary); color:#fff; font-weight:700; }
.hours-table tbody th { background: var(--c-primary-light); width: 26%; }
.hours-table .o { color: var(--c-primary-dark); font-weight: 700; }
.hours-table .x { color: var(--c-danger); font-weight: 700; }
.hours-note { color: var(--c-muted); font-size: .88rem; margin-top: 14px; }

.news-list { list-style: none; margin: 0; padding: 0; }
.news-list li { border-bottom: 1px solid var(--c-line); }
.news-list a, .news-list .news-row { display: grid; grid-template-columns: 130px 88px 1fr; gap: 16px; align-items: center; padding: 18px 8px; color: var(--c-text); }
.news-list a:hover { background: var(--c-primary-light); }
.news-date { color: var(--c-muted); font-size: .9rem; font-variant-numeric: tabular-nums; }
.news-cat { display: inline-block; text-align: center; font-size: .74rem; font-weight: 700; padding: 4px 0; border-radius: 999px; background: var(--c-primary-light); color: var(--c-primary-darker); }
.news-cat[data-cat="休診"], .news-cat[data-cat="臨時休診"] { background: var(--c-accent-soft); color:#c2671f; }
.news-cat[data-cat="予防接種"] { background:#e6f0fb; color:#2f6db5; }
.news-cat[data-cat="重要"] { background:#fbe6e6; color:#c0392b; }
.news-title { font-weight: 500; }
.news-empty { color: var(--c-muted); padding: 24px 8px; }
.news-more { text-align: center; margin-top: 30px; }

.calendar-wrap { background:#fff; border:1px solid var(--c-line); border-radius: var(--radius); box-shadow: var(--shadow); padding: 22px; max-width: 560px; margin: 0 auto; }
.cal-head { display:flex; align-items:center; justify-content: space-between; margin-bottom: 16px; }
.cal-head h3 { margin:0; font-size: 1.2rem; }
.cal-nav { display:flex; gap: 8px; }
.cal-nav button { width: 38px; height: 38px; border-radius: 10px; border: 1px solid var(--c-line); background:#fff; cursor:pointer; font-size:1rem; color: var(--c-primary-dark); transition: .2s; }
.cal-nav button:hover { background: var(--c-primary-light); }
.cal-grid { display: grid; grid-template-columns: repeat(7,1fr); gap: 6px; }
.cal-grid .dow { text-align:center; font-size:.8rem; font-weight:700; color: var(--c-muted); padding: 6px 0; }
.cal-grid .dow.sun { color: var(--c-danger); }
.cal-grid .dow.sat { color: #2f6db5; }
.cal-cell { position: relative; aspect-ratio: 1/1; border-radius: 10px; display:flex; flex-direction:column; align-items:center; justify-content:center; font-size:.95rem; background: var(--c-primary-light); color: var(--c-primary-darker); font-weight:600; }
.cal-cell.empty { background: transparent; }
.cal-cell.closed { background: #fce4e1; color: #c0392b; box-shadow: inset 0 0 0 1.5px #f1b7ae; }
.cal-cell.am-only { background: #e7f0fb; color: #2f6db5; box-shadow: inset 0 0 0 1.5px #b9d3f0; }
.cal-cell.today { outline: 2.5px solid var(--c-primary); outline-offset: -2.5px; }
.cal-cell .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--c-accent); margin-top: 3px; }
.cal-cell.has-news { cursor: pointer; }
.cal-cell.has-news:hover { box-shadow: 0 0 0 2px var(--c-accent) inset; }
.cal-legend { display:flex; gap: 18px; flex-wrap: wrap; justify-content:center; margin-top: 18px; font-size:.82rem; color: var(--c-muted); }
.cal-legend span { display:inline-flex; align-items:center; gap:6px; }
.cal-legend i { width: 14px; height: 14px; border-radius: 4px; display:inline-block; }
.cal-legend i.open { background: var(--c-primary-light); border:1px solid var(--c-primary-soft); }
.cal-legend i.am { background:#e7f0fb; border:1px solid #b9d3f0; }
.cal-legend i.close { background:#fce4e1; border:1px solid #f1b7ae; }
.cal-legend i.news { background: var(--c-accent); }
.cal-news-pop { margin-top: 16px; background: var(--c-accent-soft); border-radius: var(--radius-sm); padding: 14px 16px; font-size: .9rem; display: none; }
.cal-news-pop.show { display:block; }
.cal-news-pop strong { display:block; color:#c2671f; margin-bottom:4px; }
.cal-cell .cnum { font-size: .95rem; line-height: 1; }
.cal-cell .cmark { font-size: .58rem; font-weight: 700; margin-top: 2px; padding: 0 4px; border-radius: 4px; background: rgba(192,57,43,.14); }
.cal-cell .cmark.am { background: rgba(47,109,181,.16); color:#2f6db5; }
.cal-cell:not(.empty) { cursor: pointer; }
.cal-cell:not(.empty):hover { box-shadow: 0 0 0 2px var(--c-primary) inset; }
.cal-cell.selected { box-shadow: 0 0 0 3px var(--c-primary) inset, var(--shadow); transform: translateY(-1px); }

.pop-status { font-weight: 700; margin: 4px 0; }
.pop-status.closed { color: #c0392b; }
.pop-status.am-only { color: #2f6db5; }
.pop-status.open { color: var(--c-primary-dark); }
.cal-news-pop .pop-note { margin: 2px 0 6px; }
.cal-news-pop a { font-weight: 700; }


.article-page { max-width: 800px; margin: 0 auto; }
.article-head { border-bottom: 2px solid var(--c-primary-light); padding-bottom: 20px; margin-bottom: 30px; }
.article-meta { display:flex; gap: 12px; align-items:center; margin-bottom: 12px; }
.article-head h1 { font-size: 1.8rem; margin: 0; }
.article-body { font-size: 1.04rem; }
.article-body h2 { font-size: 1.35rem; margin: 34px 0 14px; padding-left: 14px; border-left: 5px solid var(--c-primary); }
.article-body h3 { font-size: 1.15rem; margin: 26px 0 10px; color: var(--c-primary-darker); }
.article-body p { margin: 0 0 18px; }
.article-body ul, .article-body ol { margin: 0 0 18px; padding-left: 1.4em; }
.article-body li { margin-bottom: 8px; }
.article-body img { border-radius: var(--radius-sm); margin: 18px 0; }
.article-body table { width:100%; border-collapse: collapse; margin: 18px 0; }
.article-body th, .article-body td { border:1px solid var(--c-line); padding: 10px 12px; }
.article-body th { background: var(--c-primary-light); }
.article-body blockquote { margin: 18px 0; padding: 12px 18px; background: var(--c-primary-light); border-radius: var(--radius-sm); color: var(--c-primary-darker); }
.article-back { display:inline-flex; gap:6px; margin-bottom: 24px; color: var(--c-muted); }

.page-hero { background: var(--c-primary-light); padding: 50px 0; text-align:center; }
.page-hero h1 { margin: 0 0 6px; font-size: 1.9rem; }
.page-hero .en { color: var(--c-primary); letter-spacing:.15em; font-size:.78rem; font-weight:700; text-transform:uppercase; }
.breadcrumb { font-size:.82rem; color: var(--c-muted); padding: 14px 0; }
.breadcrumb a { color: var(--c-muted); }

.info-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 30px; align-items:start; }
.info-table { width:100%; border-collapse: collapse; background:#fff; border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow); }
.info-table th, .info-table td { padding: 16px; text-align:left; border-bottom:1px solid var(--c-line); font-size:.96rem; vertical-align: top; }
.info-table th { background: var(--c-primary-light); width: 34%; white-space: nowrap; }
.map-embed { border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow); min-height: 320px; border: 0; width: 100%; }

.site-footer { background: var(--c-primary-darker); color: #dff0e7; padding: 38px 0 20px; margin-top: 20px; }
.footer-top { display:grid; grid-template-columns: 1.6fr 1fr 1.2fr; gap: 28px; align-items:start; }
.site-footer h4 { color:#fff; margin: 0 0 14px; font-size: 1rem; }
.site-footer a { color:#dff0e7; }
.site-footer a:hover { color:#fff; }
.footer-brand strong { color:#fff; font-size: 1.2rem; }
.footer-links { list-style:none; margin:0; padding:0; }
.footer-links li { margin-bottom: 8px; font-size:.9rem; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.18); margin-top: 22px; padding-top: 14px; text-align:center; font-size:.8rem; color:#b9d9c8; }
.footer-brand .f-corp { margin: 6px 0 10px; font-size:.9rem; opacity:.9; }
.footer-brand .f-addr { margin: 0 0 4px; font-size:.92rem; }
.footer-brand .f-tel { margin: 0; font-size:1rem; font-weight:700; color:#fff; }
.footer-col h4 { margin-bottom: 10px; }

/* アコーディオン（施設基準など） */
.accordion { max-width: 880px; margin: 0 auto; }
.accordion details { background:#fff; border:1px solid var(--c-line); border-radius: var(--radius-sm); margin-bottom: 10px; box-shadow: var(--shadow); }
.accordion summary { cursor:pointer; padding: 16px 18px; font-weight:700; color: var(--c-primary-darker); list-style:none; position:relative; padding-right:44px; }
.accordion summary::-webkit-details-marker { display:none; }
.accordion summary::after { content:"+"; position:absolute; right:18px; top:50%; transform:translateY(-50%); font-size:1.3rem; color:var(--c-primary); }
.accordion details[open] summary::after { content:"−"; }
.accordion details p { margin: 0; padding: 0 18px 16px; color: var(--c-muted); font-size:.95rem; }


.float-bar { display:none; }
.mt-0{margin-top:0}.text-center{text-align:center}.mb-24{margin-bottom:24px}

@media (max-width: 900px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-visual { order: -1; aspect-ratio: 16/9; }
  .cards { grid-template-columns: 1fr 1fr; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .info-grid { grid-template-columns: 1fr; }
}
/* タブレット以下：ナビをハンバーガーに、電話・WEB予約は常時表示 */
@media (max-width: 1000px) {
  .nav-toggle { display: block; }
  .nav { position: fixed; inset: 74px 0 auto 0; flex-direction: column; align-items: stretch; background:#fff; border-bottom: 1px solid var(--c-line); gap: 0; padding: 8px 16px 18px; transform: translateY(-130%); transition: transform .32s ease; box-shadow: var(--shadow-lg); max-height: calc(100vh - 74px); overflow:auto; z-index: 99; }
  .nav.is-open { transform: translateY(0); }
  .nav a { padding: 14px 8px; border-bottom: 1px solid var(--c-line); border-radius: 0; font-size: 1rem; }
}

@media (max-width: 760px) {
  .hero h1 { font-size: 1.85rem; }
  .quick-strip .container { grid-template-columns: 1fr; }
  .quick-item + .quick-item { border-left: none; border-top: 1px solid var(--c-line); }
  .cards { grid-template-columns: 1fr; }
  .section { padding: 48px 0; }
  .news-list a, .news-list .news-row { grid-template-columns: 84px 1fr; }
  .news-list .news-cat { grid-row: 1; }
  .news-list .news-date { grid-column: 1 / -1; }
  .footer-top { grid-template-columns: 1fr; }
  /* ヘッダーの電話はアイコン＋番号をコンパクトに */
  .h-tel { padding: 5px 10px; }
  .h-tel .h-tel-text small { display: none; }
  .h-tel .h-tel-text strong { font-size: 1rem; }
  .h-reserve { padding: 9px 12px; font-size: .9rem; }
  /* 下部固定バー（電話 / WEB予約） */
  .float-bar { display:flex; position: fixed; left:0; right:0; bottom:0; z-index: 90; box-shadow: 0 -4px 16px rgba(0,0,0,.12); }
  .float-bar .fb-btn { flex:1; display:flex; align-items:center; justify-content:center; gap:8px; padding: 13px 8px; font-weight:700; color:#fff; font-size:.98rem; }
  .float-bar .fb-tel { background: var(--c-primary-dark); }
  .float-bar .fb-tel b { font-variant-numeric: tabular-nums; }
  .float-bar .fb-reserve { background: var(--c-accent); }
  .float-bar .fb-btn:hover { color:#fff; }
  body { padding-bottom: 58px; }
}

@media (max-width: 380px) {
  .h-tel .h-ico { display:none; }
  .h-tel { padding: 5px 8px; }
}

/* ============== Director page ============== */
.director-intro { display:grid; grid-template-columns: 280px 1fr; gap: 36px; align-items:start; }
.director-photo { border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow); background:#fff; }
.director-photo .name-plate { padding: 14px 16px; text-align:center; }
.director-photo .name-plate small { color: var(--c-muted); }
.director-photo .name-plate strong { font-size: 1.2rem; display:block; }
.director-intro h2 { font-size: 1.5rem; margin: 0 0 16px; }
.director-intro p { margin: 0 0 16px; }
.timeline { list-style:none; margin:0; padding:0; }
.timeline li { display:grid; grid-template-columns: 200px 1fr; gap: 18px; padding: 14px 0; border-bottom:1px dashed var(--c-line); }
.timeline .ty { color: var(--c-primary-darker); font-weight:700; }
.qual-list { display:flex; flex-wrap:wrap; gap:10px; list-style:none; padding:0; margin:0; justify-content:center; }
.qual-list li { background:var(--c-primary-light); color:var(--c-primary-darker); font-weight:600; padding:8px 16px; border-radius:999px; font-size:.92rem; }
@media (max-width: 760px){
  .director-intro { grid-template-columns: 1fr; }
  .director-photo { max-width: 280px; margin: 0 auto; }
  .timeline li { grid-template-columns: 1fr; gap: 2px; }
}

/* ============== Reservation banner / QR ============== */
.reserve-banner { background: linear-gradient(135deg, var(--c-primary), var(--c-primary-dark)); color:#fff; border-radius: var(--radius); box-shadow: var(--shadow-lg); padding: 32px; display:grid; grid-template-columns: 1fr auto; gap: 28px; align-items:center; }
.reserve-banner .rb-lead small { display:block; letter-spacing:.12em; font-weight:700; opacity:.9; font-size:.78rem; }
.reserve-banner h2 { margin: 6px 0 10px; font-size: 1.6rem; }
.reserve-banner p { margin: 0 0 18px; opacity:.95; }
.reserve-banner .rb-actions { display:flex; gap:12px; flex-wrap:wrap; }
.reserve-banner .btn--white { background:#fff; color: var(--c-primary-dark); border-color:#fff; }
.reserve-banner .btn--white:hover { background: var(--c-primary-light); color: var(--c-primary-darker); }
.reserve-banner .btn--tel { background: rgba(255,255,255,.15); color:#fff; border-color: rgba(255,255,255,.5); }
.reserve-banner .btn--tel:hover { background: rgba(255,255,255,.28); color:#fff; }
.qr-card { background:#fff; border-radius: var(--radius-sm); padding: 14px; text-align:center; color: var(--c-text); width: 184px; }
.qr-card img { width: 156px; height: 156px; margin: 0 auto 8px; display:block; }
.qr-card small { font-size:.74rem; color: var(--c-muted); }
@media (max-width: 760px){
  .reserve-banner { grid-template-columns: 1fr; text-align:center; padding: 26px 20px; }
  .reserve-banner .rb-actions { justify-content:center; }
  .qr-card { margin: 0 auto; }
}

/* 院長ページ（写真なし） */
.director-intro.no-photo { display:block; max-width: 820px; }
.director-name { margin: 0 0 18px; display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; padding-bottom:14px; border-bottom:2px solid var(--c-primary-light); }
.director-name span { background:var(--c-primary); color:#fff; font-size:.78rem; font-weight:700; padding:3px 12px; border-radius:999px; }
.director-name strong { font-size:1.7rem; }
.director-name small { color:var(--c-muted); }

/* ============== Line icons ============== */
.card-ico .ico { width: 30px; height: 30px; color: var(--c-primary-dark); }
.qi-ico { display: inline-flex; }
.qi-ico .ico { width: 26px; height: 26px; color: var(--c-primary); }

.qr-fallback { font-size:.74rem; color: var(--c-muted); padding: 14px 8px; line-height:1.5; }

.cal-news-pop .pop-holiday { color:#c0392b; font-weight:700; margin:2px 0; }

/* お知らせ 絞り込みボタン */
.news-filter { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:22px; }
.news-filter-btn { border:1.5px solid var(--c-line); background:#fff; color:var(--c-muted); font-weight:700; font-size:.88rem; padding:8px 16px; border-radius:999px; cursor:pointer; transition:.18s; font-family:inherit; }
.news-filter-btn:hover { border-color:var(--c-primary); color:var(--c-primary-dark); }
.news-filter-btn.active { background:var(--c-primary); border-color:var(--c-primary); color:#fff; }

/* 乳児健診・予防接種の時間 表示 */
.hours-callout { display:flex; align-items:center; gap:14px; background:#fff6e9; border:1.5px solid #f3d29a; border-radius:12px; padding:14px 18px; margin:16px 0; max-width:560px; }
.hours-callout .hc-ico { font-size:1.6rem; }
.hours-callout .hc-label { display:block; font-weight:700; color:#c2671f; font-size:.95rem; }
.hours-callout .hc-time { display:block; font-weight:700; color:#2f3e36; font-size:1.05rem; letter-spacing:.02em; }

/* ============================================================
   スマートフォン表示の最適化（追加）
   ============================================================ */
.table-scroll { width: 100%; }
@media (max-width: 760px) {
  /* ヘッダー：上部は電話・WEB予約を出さずロゴのみ（電話/予約は画面下部の固定バーに表示） */
  .header-actions { display: none !important; }
  .brand-logo { height: 38px; max-height: 38px; width: auto; flex: 0 0 auto; }
  .header-inner { height: 62px; }
  .nav { inset: 62px 0 auto 0; max-height: calc(100vh - 62px); }

  /* ヒーロー：中央そろえ・ボタン中央 */
  .hero-inner { text-align: center; padding: 38px 0; }
  .hero .tagline, .hero p.lead { text-align: center; }
  .hero-actions { justify-content: center; }
  .hero-actions .btn { flex: 0 1 auto; }

  /* クイック情報：中央そろえ */
  .quick-item { justify-content: center; text-align: center; }

  /* お知らせ一覧（index・news共通）：全幅・読みやすく中央寄せのフィルタ */
  .news-filter { justify-content: center; }
  .news-list a, .news-list .news-row { display: block; grid-template-columns: none; padding: 14px 12px; }
  .news-list .news-date { display: inline-block; margin-right: 10px; font-size: .82rem; }
  .news-list .news-cat { display: inline-block; width: auto; padding: 3px 12px; vertical-align: middle; }
  .news-list .news-title { display: block; margin-top: 6px; font-size: .98rem; line-height: 1.6; }

  /* 予約バナーのボタン：縦並び・中央そろえ（電話とWEB予約をそろえる） */
  .reserve-banner .rb-actions { flex-direction: column; align-items: center; }
  .reserve-banner .rb-actions .btn { width: 100%; max-width: 280px; justify-content: center; }

  /* 表：はみ出す場合は横スクロール、文字は読みやすいサイズに */
  .table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; border: 1px solid var(--c-line); border-radius: var(--radius-sm); }
  .hours-table { font-size: .74rem; min-width: 430px; }
  .hours-table th, .hours-table td { padding: 8px 5px; }
  .hours-table thead th { font-size: .74rem; }
  .hours-table th small { font-size: .62rem; }
  .hours-table .cmark, .hours-table td span { font-size: .62rem; }
  .info-table { font-size: .82rem; min-width: 360px; }
  .info-table th, .info-table td { padding: 9px 8px; line-height: 1.5; }
}

/* 予約埋め込み */
.reserve-embed { max-width: 900px; margin: 0 auto; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-lg); border:1px solid var(--c-line); background:#fff; }
.reserve-embed iframe { width: 100%; height: 820px; border: 0; display:block; }
@media (max-width: 760px){ .reserve-embed iframe { height: 680px; } }

/* 書類ダウンロード一覧 */
.dl-item { display:flex; align-items:center; gap:18px; justify-content:space-between; background:#fff; border:1px solid var(--c-line); border-radius:var(--radius); box-shadow:var(--shadow); padding:20px 24px; margin-bottom:14px; }
.dl-item .dl-info strong { font-size:1.1rem; }
.dl-item .dl-info p { margin:6px 0 0; color:var(--c-muted); font-size:.92rem; }
.dl-item .btn { flex:0 0 auto; }
@media (max-width:600px){ .dl-item { flex-direction:column; align-items:stretch; text-align:center; } .dl-item .btn { width:100%; justify-content:center; } }

/* カレンダー：範囲外の月送りボタン */
.cal-nav button[disabled] { opacity:.3; cursor:default; }
.cal-nav button[disabled]:hover { background:#fff; }

/* カレンダー：祝日名の表示 */
.cal-cell .cmark.hol { background:transparent; color:#c0392b; font-size:.5rem; font-weight:700; line-height:1.05; margin-top:1px; padding:0 1px; white-space:normal; word-break:break-all; max-height:2.3em; overflow:hidden; }
.cal-cell .cnum { line-height:1; }
