/*
Theme Name: 認知症疾患医療センター (ninchi)
Theme URI: https://www.abeclinic-ninchi.com/
Description: 認知症疾患医療センター - あべクリニック の自作シンプルテーマ。WPBakery/Mr.Tailor非依存の素PHPクラシックテーマ。高齢者にも読みやすい大きめ文字・高コントラスト設計。
Author: Masafumi Umetsu
Version: 0.1.0
Requires at least: 6.0
Requires PHP: 8.0
Text Domain: ninchi
*/

/* =========================================================
   1. ベース / リセット
   ========================================================= */
:root{
  --brand:#ff6600;        /* ブランドオレンジ（鮮やか）。上ライン・メニュー・差し色に“少量”使う */
  --brand-2:#ff9900;      /* サブオレンジ（細い差し色用） */
  --brand-dark:#e55a00;   /* ホバー・アクティブ */
  --ink:#3a3a3a;          /* 本文 */
  --ink-soft:#6b6b6b;     /* やや薄い本文 */
  --line:#e6e3df;         /* 罫線 */
  --bg-soft:#faf7f3;      /* 薄背景（ほんのり暖色） */
  --link:#1769aa;
  --max:1080px;
  --radius:6px;
}

*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:"Hiragino Sans","Hiragino Kaku Gothic ProN","BIZ UDPGothic","Noto Sans JP","Yu Gothic Medium","Yu Gothic",Meiryo,sans-serif;
  font-size:17px;
  font-weight:400;
  line-height:1.9;
  letter-spacing:.02em;
  color:var(--ink);
  background:#fff;
  word-break:break-word;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;vertical-align:middle;}
a{color:var(--link);text-underline-offset:.15em;}
a:hover{color:var(--brand-dark);}
h1,h2,h3,h4{line-height:1.5;color:#2b2b2b;font-weight:600;}

/* 読みやすさ：本文リンクとフォーカス */
:focus-visible{outline:3px solid var(--brand-2);outline-offset:2px;}

.container{max-width:var(--max);margin-inline:auto;padding-inline:20px;}
.skip-link{position:absolute;left:-9999px;}
.skip-link:focus{left:8px;top:8px;background:#fff;padding:8px 12px;z-index:1000;}

/* =========================================================
   2. ヘッダー
   ========================================================= */
.site-header{border-top:5px solid var(--brand);background:#fff;}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-block:14px;}
.site-branding a{display:inline-block;line-height:0;}
.site-branding img{max-height:64px;width:auto;max-width:100%;}
.site-title-text{font-size:1.2rem;font-weight:700;color:var(--brand);text-decoration:none;}
/* site-desc: デスクトップ→右端、モバイル/タブレット→ロゴ下 */
.site-desc{font-size:.8rem;color:var(--ink-soft);line-height:1.5;margin:0;text-align:right;}

/* =========================================================
   3. グローバルナビ
   ========================================================= */
.main-nav{background:var(--brand);}
.main-nav .container{padding-inline:0;}
.nav-menu{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;}
.nav-menu li{position:relative;}
.nav-menu a{
  display:block;color:#fff;text-decoration:none;
  padding:14px 18px;font-weight:500;font-size:1rem;
}
.nav-menu > li > a:hover,.nav-menu > li:focus-within > a{background:var(--brand-dark);}
/* ドロップダウン（2階層） */
.nav-menu .sub-menu{
  list-style:none;margin:0;padding:0;
  position:absolute;left:0;top:100%;min-width:240px;
  background:var(--brand-dark);
  box-shadow:0 6px 18px rgba(0,0,0,.18);
  opacity:0;visibility:hidden;transform:translateY(6px);
  transition:.15s;z-index:50;
}
.nav-menu li:hover > .sub-menu,
.nav-menu li:focus-within > .sub-menu{opacity:1;visibility:visible;transform:none;}
.nav-menu .sub-menu a{padding:12px 18px;font-weight:500;border-top:1px solid rgba(255,255,255,.15);}
.nav-menu .sub-menu a:hover{background:#c95000;}
.menu-item-has-children > a::after{content:"▾";margin-left:6px;font-size:.8em;}

/* ハンバーガー（モバイル） */
.nav-toggle{display:none;}
.nav-toggle-btn{
  display:none;align-items:center;gap:8px;
  background:var(--brand);color:#fff;border:0;width:100%;
  padding:14px 18px;font-size:1.05rem;font-weight:700;cursor:pointer;
}
.nav-toggle-icon{font-style:normal;font-size:1.2em;line-height:1;}
.nav-toggle-icon::before{content:"☰";}
.nav-toggle:checked ~ .nav-toggle-btn .nav-toggle-icon::before{content:"✕";}

/* =========================================================
   4. レイアウト本体
   ========================================================= */
.site-main{padding-block:32px 48px;}
.layout{display:grid;grid-template-columns:1fr 300px;gap:40px;align-items:start;}
.layout--full{grid-template-columns:1fr;}

.page-title{
  font-size:1.6rem;margin:0 0 24px;padding:6px 0 6px 14px;
  border-left:6px solid var(--brand);
}

.entry-content{font-size:1.0625rem;}
.entry-content h2{
  font-size:1.35rem;margin:2em 0 .8em;padding:2px 0 8px 14px;
  border-left:4px solid var(--brand);border-bottom:1px solid var(--line);
  background:none;
}
.entry-content h3{
  font-size:1.15rem;margin:1.8em 0 .6em;
  padding:0;border:none;
}
.entry-content h3::before{
  content:"●";color:var(--brand);
  font-size:.85em;margin-right:.45em;vertical-align:.05em;
}
.entry-content p{margin:0 0 1.2em;}
.entry-content ul,.entry-content ol{margin:0 0 1.2em;padding-left:1.6em;}
.entry-content table{border-collapse:collapse;width:100%;margin:0 0 1.4em;}
.entry-content th,.entry-content td{border:1px solid var(--line);padding:10px 12px;}
.entry-content th{background:var(--bg-soft);text-align:left;}
.entry-content img{height:auto;}
.entry-content a{color:var(--link);text-decoration:underline;}
.entry-content .btn{text-decoration:none;}

/* =========================================================
   5. お知らせ / 投稿一覧
   ========================================================= */
.post-list{list-style:none;margin:0;padding:0;}
.post-list__item{padding:16px 0;border-bottom:1px solid var(--line);}
.post-list__item a{font-size:1.05rem;font-weight:600;text-decoration:none;color:var(--ink);}
.post-list__item a:hover{color:var(--brand-dark);text-decoration:underline;}

/* カード型リスト（活動報告） */
.post-list--card .post-list__item--card{display:flex;gap:16px;align-items:flex-start;padding:18px 0;}
.post-list__thumb{flex:0 0 120px;}
.post-list__thumb img{width:120px;height:80px;object-fit:cover;border:1px solid var(--line);border-radius:var(--radius);display:block;}
.post-list__thumb--empty{width:120px;height:80px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);}
.post-list__info{flex:1;min-width:0;}
.post-list__date{display:block;font-size:.85rem;color:var(--ink-soft);margin-bottom:4px;}
.post-list__title{font-size:1rem;font-weight:600;text-decoration:none;color:var(--ink);display:block;line-height:1.6;}
.post-list__title:hover{color:var(--brand-dark);text-decoration:underline;}

/* 個別記事アイキャッチ */
.single-thumbnail{margin:0 0 24px;text-align:center;}
.single-thumbnail img{max-width:100%;height:auto;border-radius:var(--radius);}

.post-meta{display:flex;gap:12px;align-items:center;font-size:.85rem;color:var(--ink-soft);margin-bottom:4px;}
.cat-badge{background:var(--brand);color:#fff;font-size:.78rem;padding:2px 10px;border-radius:999px;}

/* ページネーション */
.pagination{display:flex;gap:8px;flex-wrap:wrap;margin-top:28px;}
.pagination .page-numbers{
  display:inline-block;padding:8px 14px;border:1px solid var(--line);
  text-decoration:none;border-radius:var(--radius);color:var(--brand-dark);
}
.pagination .current{background:var(--brand);color:#fff;border-color:var(--brand);}

/* =========================================================
   6. サイドバー
   ========================================================= */
.sidebar{position:sticky;top:24px;}
.sidebar .widget{margin-bottom:28px;}
.sidebar .widget-title{
  font-size:1.05rem;margin:0 0 12px;padding:6px 10px;
  background:var(--brand);color:#fff;border-radius:var(--radius) var(--radius) 0 0;
}
.sidebar ul{list-style:none;margin:0;padding:0;}
.sidebar li{border-bottom:1px solid var(--line);}
.sidebar li a{display:block;padding:10px 6px;text-decoration:none;color:var(--ink);}
.sidebar li a:hover{color:var(--brand-dark);}
.sidebar .banner-list a{border:0;padding:6px 0;}

/* =========================================================
   7. フッター
   ========================================================= */
.site-footer{background:#efefef;color:#676a6a;margin-top:48px;padding-block:32px;}
.site-footer a{color:var(--brand-dark);}
.footer-info{font-size:.95rem;line-height:1.9;}
.footer-separator{height:1px;background:#e1e1e1;margin:20px 0;}
.copyright{font-size:.85rem;color:#676a6a;margin:0;}

/* トップに戻る */
.page-top{
  position:fixed;bottom:28px;right:28px;width:52px;height:52px;
  background:#666;color:#fff;border-radius:50%;text-align:center;
  line-height:52px;font-size:24px;text-decoration:none;z-index:900;
  opacity:.85;transition:.2s;
}
.page-top:hover{background:var(--brand);color:#fff;opacity:1;}

/* =========================================================
   8. ホーム（front-page）
   ========================================================= */
.home-section{margin-bottom:70px;}
.home-section__title{
  font-size:1.4rem;margin:0 0 16px;padding:2px 0 8px 14px;
  border-left:4px solid var(--brand);border-bottom:1px solid var(--line);
  background:none;
}
.home-lead{font-size:1.05rem;background:var(--bg-soft);padding:20px;border-radius:var(--radius);}

/* ボタン（アウトライン・ピル型＋矢印 / 塗りはホバー時のみ） */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  background:transparent;color:var(--brand) !important;
  text-decoration:none;font-weight:600;line-height:1.4;
  padding:11px 26px;border:2px solid var(--brand);border-radius:999px;
  cursor:pointer;transition:background .2s,color .2s;
}
.btn::after{content:"→";transition:transform .2s;}
.btn:hover{background:var(--brand);color:#fff !important;}
.btn:hover::after{transform:translateX(4px);}
.btn--block{display:flex;justify-content:center;}
.btn-row{margin:18px 0;}

/* YouTube等の埋め込み（レスポンシブ） */
.embed-responsive{position:relative;width:100%;padding-top:56.25%;margin:16px 0;}
.embed-responsive iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}

/* 連絡先ボックス（緑アウトライン） */
.contact-box{
  border:2px solid #4caf50;border-radius:10px;padding:18px 20px;
  background:#f4fbf4;margin-bottom:24px;
}
.contact-box p{margin:.3em 0;}
.contact-box hr{border:0;border-top:1px solid #cfe6cf;margin:12px 0;}
.contact-box .tel{font-size:1.5rem;font-weight:700;display:block;margin-top:4px;}
.contact-box .tel a{color:var(--brand-dark);text-decoration:none;}
.contact-box .tel a::before{content:"\260E";margin-right:8px;}

/* バナー列 */
.banner-list{display:block;}
.banner-list a{display:block;margin-bottom:10px;}
.banner-list img{width:100%;height:auto;border:1px solid var(--line);}
.banner-list .label{text-align:center;font-size:.95rem;margin:18px 0 8px;color:var(--ink-soft);}

/* 2列グリッド（Newsletter / vc_column_inner 1/2 変換後） */
.grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:8px 0;}
.grid-2col > :not(.grid-col){grid-column:1 / -1;} /* 非grid-colは全幅 */
.grid-col{min-width:0;}
.grid-col p{margin:.3em 0 .5em;}
.grid-col img,.grid-col a>img{width:100%;height:auto;display:block;}
@media (max-width:600px){.grid-2col{grid-template-columns:1fr;}}

/* 投稿一覧 */
.post-list{list-style:none;margin:0;padding:0;}
.post-list__item{display:flex;flex-wrap:wrap;gap:8px 12px;align-items:baseline;padding:12px 0;border-bottom:1px solid var(--line);}
.post-list__item:first-child{border-top:1px solid var(--line);}
.post-list__date{font-size:.9rem;color:var(--ink-soft);white-space:nowrap;}
.post-list__item a{color:var(--ink);text-decoration:none;}
.post-list__item a:hover{color:var(--brand-dark);text-decoration:underline;}
.pagination{text-align:center;margin:24px 0;}
.pagination .page-numbers{display:inline-block;margin:0 4px;padding:6px 12px;border:1px solid var(--line);border-radius:4px;color:var(--ink);text-decoration:none;}
.pagination .page-numbers.current{background:var(--brand);color:#fff;border-color:var(--brand);}
.pagination .page-numbers:hover:not(.current){border-color:var(--brand);color:var(--brand-dark);}

/* 本文中の画像 */
.content-figure{margin:18px 0;text-align:center;}
.content-figure img{max-width:100%;height:auto;border-radius:4px;}

/* 地図埋め込み */
.map-embed{position:relative;width:100%;margin:16px 0;}
.map-embed iframe{width:100%;height:420px;border:0;border-radius:4px;}

/* 注意ボックス（旧 vc_message） */
.notice-box{
  border:1px solid #cfe6cf;background:#f4fbf4;border-radius:8px;
  padding:14px 18px;margin:16px 0;
}

/* ホームのニュース日付 */
.home-date{color:var(--brand);font-weight:700;}
.home-figure{margin:16px 0;text-align:center;}
.home-figure img{max-width:100%;height:auto;}
.nipporing-title{font-size:1.05rem;font-weight:700;margin:.3em 0 .6em;}
.nipporing-title a{color:var(--ink);text-decoration:none;}
.nipporing-title a:hover{color:var(--brand-dark);}
.nipporing-excerpt p{margin:.4em 0;}

/* にっぽりんぐ一覧（archive-nipporing.php） */
.nipporing-list{margin:0;}
.nipporing-list__item{
  padding:24px 0;border-bottom:1px solid var(--line);
}
.nipporing-list__item:first-child{border-top:1px solid var(--line);}
.nipporing-list__meta{margin-bottom:6px;}
.nipporing-list__body{display:flex;gap:20px;align-items:flex-start;}
.nipporing-list__thumb{flex:0 0 160px;margin:0;}
.nipporing-list__thumb img{width:100%;height:auto;border:1px solid var(--line);}
.nipporing-list__text{flex:1;min-width:0;}
.nipporing-list__title{font-size:1.05rem;font-weight:700;margin:0 0 .5em;}
.nipporing-list__title a{color:var(--ink);text-decoration:none;}
.nipporing-list__title a:hover{color:var(--brand-dark);}
.nipporing-list__excerpt p{margin:.3em 0;font-size:.95rem;}
@media (max-width:600px){
  .nipporing-list__body{flex-direction:column;}
  .nipporing-list__thumb{flex:0 0 auto;width:100%;}
}

/* =========================================================
   9. Q&A ページ（ID:382）— abeclinic.com/fme/ 形式 + オレンジ下線
   ========================================================= */
.page-id-382 .entry-content h3{
  font-size:1.1rem;font-weight:700;color:var(--ink-soft);
  padding:10px 0;border:none;
  margin:32px 0 16px;
}
.page-id-382 .entry-content h3::before{
  content:"●";color:var(--brand);
  font-size:.85em;margin-right:.45em;vertical-align:.05em;
}
.page-id-382 .entry-content .fa{display:none;} /* FA icon 非表示 */
.page-id-382 .entry-content dl{margin:0;}
.page-id-382 .entry-content dl dt{
  font-size:1.1rem;font-weight:700;color:var(--ink);
  padding:0 0 10px;margin:28px 0 10px;
  border-bottom:2px solid var(--line);
  position:relative;list-style:none;
}
.page-id-382 .entry-content dl dt::first-letter{
  padding-right:.4em;
}
.page-id-382 .entry-content dl dt::after{
  content:"";position:absolute;left:0;bottom:-2px;
  width:56px;height:2px;background:var(--brand);
}
.page-id-382 .entry-content dl dd{
  font-size:1rem;line-height:1.95;
  margin:8px 0 28px;padding:0;
}
.page-id-382 .entry-content dl dd::first-letter{
  font-weight:700;padding-right:.4em;
}

/* =========================================================
   10. レスポンシブ
   ========================================================= */
/* ≤1100px: ハンバーガーメニューに切り替え & site-desc をロゴ下に */
@media (max-width:1100px){
  body{font-size:16px;}
  /* site-desc をロゴの下（縦並び） */
  .site-header__inner{flex-wrap:wrap;gap:4px 16px;}
  .site-branding{flex:0 0 auto;}
  .site-branding img{max-height:45px;width:auto;}
  .site-desc{flex:0 0 100%;text-align:left;padding:2px 0 4px;order:1;}
  /* ハンバーガー：stickyで最上部に固定 */
  .main-nav{background:var(--brand);position:sticky;top:0;z-index:200;}
  .nav-toggle-btn{display:flex;}
  .nav-menu{display:none;flex-direction:column;background:#f7f7f7;}
  .nav-toggle:checked ~ .nav-menu{display:flex;}
  .nav-menu a{color:#444;border-top:1px solid #e0e0e0;}
  .nav-menu > li > a:hover,.nav-menu > li:focus-within > a{background:#e8e8e8;color:var(--brand-dark);}
  .nav-menu .sub-menu{
    position:static;opacity:1;visibility:visible;transform:none;
    box-shadow:none;min-width:0;background:#ececec;
  }
  .nav-menu .sub-menu a{color:#555;border-top:1px solid #ddd;}
  .nav-menu .sub-menu a:hover{background:#e0e0e0;color:var(--brand-dark);}
  .menu-item-has-children > a::after{content:"＋";float:right;}
  .page-top{width:46px;height:46px;line-height:46px;bottom:16px;right:16px;}
}
@media (max-width:900px){
  .layout{grid-template-columns:1fr;gap:32px;}
  /* サイドバーのバナーを2列グリッドに */
  .banner-list{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:start;}
  .banner-list a{margin-bottom:0;}
  .banner-list .label{grid-column:1 / -1;margin:12px 0 4px;}
}
