/*
Theme Name: for ライフ みらい
Theme URI: 
Author: for ライフ みらい
Description: 就労継続支援B型事業所 for ライフ みらい 公式サイトテーマ
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: forlifemiral
Tags: japanese, welfare, single-page
*/

/* ============================================================
   for ライフ みらい ― 公式サイト スタイル v6 (Bright Yellow-Green)
   ============================================================ */

/* ── CSS 変数 ── */
:root {
  /* 明るい黄緑パレット */
  --b1: #4a7c2f;   /* 深みのある明黄緑（ヘッダー・フッター） */
  --b2: #6ab42e;   /* メイン 鮮やか黄緑 */
  --b3: #92d050;   /* 明るいライム黄緑 */
  --b4: #c6e88a;   /* 淡い黄緑 */
  --b5: #edfacc;   /* 背景 ペールライム */
  /* 後方互換エイリアス */
  --g1: var(--b1);
  --g2: var(--b2);
  --g3: var(--b3);
  --g4: var(--b4);
  --g5: var(--b5);
  --ora: #f0a500;  /* 黄色アクセント */
  --ora2: #fffbe6; /* 薄黄 */
  --txt: #1e2a10;
  --txt2: #3a4a28;
  --txt3: #6a7a58;
  --wh: #ffffff;
  --bg: #f5fce8;   /* ペールライム背景 */
  --bd: #b8e05c;   /* 黄緑ボーダー */
  --sh1: 0 2px 16px rgba(106,180,46,.15);
  --sh2: 0 8px 40px rgba(106,180,46,.25);
  --r1: 4px;
  --r2: 12px;
  --r3: 24px;
  --r4: 999px;
  --ease: cubic-bezier(.4,0,.2,1);
  --dur: .28s;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{
  font-family:'Noto Sans JP','Hiragino Sans','Yu Gothic UI',sans-serif;
  color:var(--txt);background:var(--wh);
  line-height:1.75;overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:var(--g2);text-decoration:none;transition:color var(--dur) var(--ease)}
a:hover{color:var(--g1)}
ul,ol{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}

/* ── ユーティリティ ── */
.container{max-width:1160px;margin:0 auto;padding:0 24px}
.section-pad{padding:96px 0}
.section-pad-sm{padding:64px 0}

.tag{
  display:inline-block;
  background:var(--g5);color:var(--g2);
  font-size:11px;font-weight:800;letter-spacing:.12em;
  padding:4px 14px;border-radius:var(--r4);
  text-transform:uppercase;
}
.tag-white{background:rgba(255,255,255,.2);color:rgba(255,255,255,.95)}
.tag-ora{background:var(--ora2);color:var(--ora)}

h2.sec-title{
  font-size:clamp(26px,4vw,40px);font-weight:900;
  color:var(--g1);line-height:1.25;margin:12px 0 8px;
}
h2.sec-title.white{color:var(--wh)}
p.sec-lead{font-size:16px;color:var(--txt2);line-height:1.85;max-width:600px}
p.sec-lead.white{color:rgba(255,255,255,.82)}

/* アニメーション */
.fade-up{opacity:0;transform:translateY(32px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.fade-left{opacity:0;transform:translateX(-32px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.fade-right{opacity:0;transform:translateX(32px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.fade-up.on,.fade-left.on,.fade-right.on{opacity:1;transform:none}
.delay-1{transition-delay:.1s}
.delay-2{transition-delay:.2s}
.delay-3{transition-delay:.3s}
.delay-4{transition-delay:.4s}
.delay-5{transition-delay:.5s}

/* ============================================================
   ヘッダー
   ============================================================ */
#hdr{
  position:fixed;top:0;left:0;right:0;z-index:900;
  background:rgba(255,255,255,.97);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--bd);
  transition:box-shadow var(--dur) var(--ease);
}
#hdr.scrolled{box-shadow:var(--sh1)}

.hdr-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:14px 24px;max-width:1160px;margin:0 auto;
}

/* ロゴ */
.logo-wrap{display:flex;align-items:center;gap:10px;flex-shrink:0}
.logo-icon{
  background:var(--g2);color:var(--wh);
  font-size:12px;font-weight:900;
  padding:6px 11px;border-radius:6px;letter-spacing:.04em;
}
.logo-name{font-size:18px;font-weight:900;color:var(--g1);line-height:1.1}
.logo-sub{font-size:10px;color:var(--txt3);margin-top:1px}

/* グローバルナビ */
#gnav ul{display:flex;gap:2px}
#gnav a{
  display:block;padding:7px 13px;border-radius:var(--r4);
  font-size:13px;font-weight:700;color:var(--txt2);
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease);
}
#gnav a:hover{background:var(--g5);color:var(--g2)}

/* ヘッダーCTA */
.hdr-cta{display:flex;gap:8px;flex-shrink:0}
.btn-tel{
  display:flex;align-items:center;gap:6px;
  background:var(--g2);color:var(--wh) !important;
  padding:8px 18px;border-radius:var(--r4);font-size:13px;font-weight:800;
  transition:background var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.btn-tel:hover{background:var(--g1);transform:translateY(-1px)}

/* ハンバーガー */
#ham{display:none;flex-direction:column;gap:5px;padding:6px}
#ham span{display:block;width:22px;height:2px;background:var(--g1);border-radius:2px;transition:all var(--dur) var(--ease)}

/* モバイルメニュー */
#mob-menu{
  display:none;position:fixed;top:64px;left:0;right:0;bottom:0;
  background:var(--wh);z-index:800;overflow-y:auto;padding:16px 24px 32px;
}
#mob-menu.open{display:block}
#mob-menu li a{
  display:block;padding:14px 4px;border-bottom:1px solid var(--bd);
  font-size:16px;font-weight:700;color:var(--txt);
}
.mob-tel-block{margin-top:24px;text-align:center}
.mob-tel-block a{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--g2);color:var(--wh);
  padding:14px 32px;border-radius:var(--r4);font-size:16px;font-weight:900;width:100%;justify-content:center;
}

/* ============================================================
   ヒーロー
   ============================================================ */
#hero{
  margin-top:64px;
  position:relative;height:calc(100vh - 64px);min-height:560px;overflow:hidden;
}

/* スライダー */
.slides{position:relative;height:100%}
.slide{
  position:absolute;inset:0;opacity:0;
  transition:opacity 1s var(--ease);
}
.slide.on{opacity:1}
.slide img{width:100%;height:100%;object-fit:cover;object-position:center}

/* オーバーレイ */
.slide-ov{
  position:absolute;inset:0;
  background:linear-gradient(
    120deg,
    rgba(51,105,30,.72) 0%,
    rgba(85,139,47,.42) 50%,
    rgba(0,0,0,.15) 100%
  );
}

/* ヒーロー本文 */
.hero-body{
  position:absolute;bottom:0;left:0;right:0;
  padding:0 40px 80px;max-width:1160px;margin:0 auto;
}
.hero-tag{
  display:inline-block;background:var(--ora);color:var(--wh);
  font-size:12px;font-weight:800;padding:5px 16px;border-radius:var(--r4);
  margin-bottom:18px;letter-spacing:.06em;
}
.hero-h1{
  font-size:clamp(32px,5.5vw,66px);font-weight:900;color:var(--wh);
  line-height:1.15;margin-bottom:18px;
  text-shadow:0 2px 24px rgba(0,0,0,.3);
}
.hero-h1 em{color:var(--g4);font-style:normal}
.hero-lead{
  font-size:clamp(14px,1.8vw,18px);color:rgba(255,255,255,.9);
  line-height:1.85;margin-bottom:36px;max-width:580px;
}
.hero-lead strong{color:var(--wh);font-weight:800}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap}

.btn-prim{
  display:inline-flex;align-items:center;gap:9px;
  background:var(--g2);color:var(--wh);
  padding:16px 32px;border-radius:var(--r4);
  font-size:15px;font-weight:800;
  box-shadow:0 4px 20px rgba(46,139,87,.4);
  transition:background var(--dur) var(--ease),transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.btn-prim:hover{background:var(--g1);transform:translateY(-3px);box-shadow:0 8px 32px rgba(46,139,87,.55);color:var(--wh)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(255,255,255,.15);color:var(--wh);
  padding:16px 32px;border-radius:var(--r4);
  font-size:15px;font-weight:800;border:2px solid rgba(255,255,255,.7);
  backdrop-filter:blur(4px);
  transition:background var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.btn-ghost:hover{background:rgba(255,255,255,.28);transform:translateY(-3px);color:var(--wh)}

/* スライダードット */
.hero-dots{
  position:absolute;bottom:28px;right:40px;
  display:flex;gap:8px;z-index:10;
}
.dot{
  width:8px;height:8px;border-radius:4px;background:rgba(255,255,255,.5);
  border:none;transition:all var(--dur) var(--ease);
}
.dot.on{width:24px;background:var(--wh)}

/* スタッツカード */
.hero-stats{
  position:absolute;top:50%;right:40px;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:12px;
}
.stat{
  background:rgba(255,255,255,.94);border-radius:var(--r2);
  padding:16px 20px;text-align:center;min-width:120px;
  box-shadow:var(--sh2);
}
.stat-n{font-size:28px;font-weight:900;color:var(--g2);line-height:1}
.stat-l{font-size:11px;color:var(--txt3);margin-top:4px;font-weight:700}

/* ============================================================
   ターゲットバー
   ============================================================ */
#target-bar{background:var(--g2);padding:0}
.tbar-inner{
  display:grid;grid-template-columns:repeat(3,1fr);
  max-width:1160px;margin:0 auto;
}
.tbar-item{
  display:flex;align-items:center;gap:14px;
  padding:22px 28px;color:rgba(255,255,255,.85);
  border-right:1px solid rgba(255,255,255,.18);
  cursor:pointer;transition:background var(--dur) var(--ease);
}
.tbar-item:last-child{border-right:none}
.tbar-item:hover{background:rgba(255,255,255,.1);color:var(--wh)}
.tbar-ico{font-size:28px;flex-shrink:0}
.tbar-t{font-size:15px;font-weight:900;color:var(--wh);margin-bottom:2px}
.tbar-s{font-size:12px;opacity:.8}
.tbar-item i{margin-left:auto;opacity:.6}

/* ============================================================
   ABOUT（わたしたちについて）
   ============================================================ */
#about{background:var(--wh)}

.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;
}
.about-img-wrap{position:relative}
.about-img-main{
  border-radius:var(--r3);overflow:hidden;
  box-shadow:var(--sh2);
  height:480px;
}
.about-img-main img{width:100%;height:100%;object-fit:cover}
.about-img-sub{
  position:absolute;bottom:-24px;right:-24px;
  width:200px;height:150px;border-radius:var(--r2);overflow:hidden;
  box-shadow:var(--sh2);border:4px solid var(--wh);
}
.about-img-sub img{width:100%;height:100%;object-fit:cover}
.about-badge{
  position:absolute;top:24px;left:-16px;
  background:var(--ora);color:var(--wh);
  padding:12px 20px;border-radius:var(--r2);
  font-size:13px;font-weight:900;line-height:1.4;
  box-shadow:var(--sh2);
}

.about-text{padding:0 0 0 8px}
.about-kpi{
  display:flex;gap:24px;margin:32px 0;
}
.kpi-item{
  background:var(--g5);border-radius:var(--r2);padding:18px 24px;flex:1;text-align:center;
}
.kpi-n{font-size:26px;font-weight:900;color:var(--g2);line-height:1}
.kpi-l{font-size:11px;color:var(--txt3);margin-top:4px;font-weight:700}

/* ============================================================
   サービス
   ============================================================ */
#services{background:var(--bg)}

.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}

.svc-card{
  background:var(--wh);border-radius:var(--r3);overflow:hidden;
  box-shadow:var(--sh1);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.svc-card:hover{transform:translateY(-8px);box-shadow:var(--sh2)}

.svc-img{position:relative;height:280px;overflow:hidden}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.svc-card:hover .svc-img img{transform:scale(1.06)}
.svc-img-ov{
  position:absolute;inset:0;
  background:linear-gradient(transparent 40%,rgba(51,105,30,.68));
}
.svc-badge{
  position:absolute;bottom:16px;left:16px;
  background:var(--ora);color:var(--wh);
  font-size:11px;font-weight:900;padding:4px 12px;border-radius:var(--r4);
}
.svc-cap{
  position:absolute;bottom:16px;right:16px;
  background:rgba(255,255,255,.92);border-radius:var(--r4);
  padding:4px 12px;font-size:12px;font-weight:800;color:var(--g1);
  display:flex;align-items:center;gap:5px;
}

.svc-body{padding:28px 28px 32px}
.svc-name{font-size:22px;font-weight:900;color:var(--g1);margin-bottom:12px}
.svc-desc{font-size:14px;color:var(--txt2);line-height:1.85;margin-bottom:20px}
.svc-list{display:flex;flex-direction:column;gap:9px}
.svc-list li{
  display:flex;align-items:flex-start;gap:8px;
  font-size:14px;color:var(--txt);
}
.svc-list li::before{
  content:'✓';color:var(--g3);font-weight:900;flex-shrink:0;margin-top:1px;
}

/* 送迎バナー */
.transfer-banner{
  margin-top:36px;
  background:linear-gradient(135deg,var(--g1) 0%,var(--g2) 100%);
  border-radius:var(--r3);padding:28px 36px;
  display:flex;align-items:center;gap:28px;flex-wrap:wrap;
}
.transfer-icon{font-size:48px;flex-shrink:0}
.transfer-text h3{font-size:18px;font-weight:900;color:var(--wh);margin-bottom:6px}
.transfer-text p{font-size:14px;color:rgba(255,255,255,.85);line-height:1.75}
.btn-white{
  display:inline-flex;align-items:center;gap:8px;flex-shrink:0;
  background:var(--wh);color:var(--g1);
  padding:12px 24px;border-radius:var(--r4);
  font-size:14px;font-weight:900;margin-left:auto;
  transition:transform var(--dur) var(--ease);
}
.btn-white:hover{transform:translateY(-2px);color:var(--g1)}

/* ============================================================
   フォトギャラリー
   ============================================================ */
#gallery{background:linear-gradient(135deg,#33691e 0%,#558b2f 100%);padding:80px 0}

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:200px 200px;
  gap:10px;margin-top:48px;
}
.gallery-item{
  border-radius:var(--r2);overflow:hidden;
  cursor:pointer;position:relative;
  transition:transform var(--dur) var(--ease);
}
.gallery-item:hover{transform:scale(1.02)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item:nth-child(1){grid-column:span 2;grid-row:span 2}/* 大きな画像 */

.gal-ov{
  position:absolute;inset:0;
  background:rgba(51,105,30,.0);
  display:flex;align-items:center;justify-content:center;
  transition:background var(--dur) var(--ease);
}
.gallery-item:hover .gal-ov{background:rgba(51,105,30,.58)}
.gal-ov span{
  color:var(--wh);font-size:13px;font-weight:700;opacity:0;
  transition:opacity var(--dur) var(--ease);
  text-align:center;padding:8px;
}
.gallery-item:hover .gal-ov span{opacity:1}

/* ライトボックス */
.lb{
  display:none;position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,.92);align-items:center;justify-content:center;
}
.lb.open{display:flex}
.lb-inner{position:relative;max-width:90vw;max-height:90vh}
.lb-inner img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:var(--r2)}
.lb-close{
  position:absolute;top:-44px;right:0;
  color:var(--wh);font-size:32px;line-height:1;
  background:none;border:none;cursor:pointer;
}

/* ============================================================
   1日の流れ
   ============================================================ */
#schedule{background:var(--wh)}

.sch-tabs{
  display:flex;gap:4px;border-bottom:2px solid var(--bd);
  margin-bottom:44px;
}
.sch-tab{
  padding:12px 28px;font-size:15px;font-weight:700;color:var(--txt3);
  border-bottom:3px solid transparent;margin-bottom:-2px;cursor:pointer;
  transition:color var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.sch-tab.on{color:var(--g2);border-bottom-color:var(--g2)}

.sch-panel{display:none}
.sch-panel.on{display:block}

.sch-layout{
  display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;
}
.sch-photo{border-radius:var(--r3);overflow:hidden;box-shadow:var(--sh2)}
.sch-photo img{width:100%;height:420px;object-fit:cover}

.timeline{display:flex;flex-direction:column}
.tl-item{
  display:flex;gap:18px;padding-bottom:20px;position:relative;
}
.tl-item:not(:last-child)::after{
  content:'';position:absolute;left:58px;top:34px;bottom:0;
  width:2px;background:var(--bd);
}
.tl-time{
  width:72px;flex-shrink:0;font-size:13px;font-weight:800;
  color:var(--g2);text-align:right;padding-top:8px;
}
.tl-dot{
  width:20px;height:20px;border-radius:50%;
  background:var(--g2);border:3px solid var(--wh);
  box-shadow:0 0 0 2px var(--g2);
  flex-shrink:0;margin-top:6px;z-index:1;
}
.tl-body{}
.tl-label{font-size:15px;font-weight:700;color:var(--txt);margin-bottom:3px}
.tl-desc{font-size:13px;color:var(--txt3);line-height:1.65}

/* ============================================================
   活動プログラム
   ============================================================ */
#activities{background:var(--bg)}

.act-layout{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}

.act-photos{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.act-photo{border-radius:var(--r2);overflow:hidden;box-shadow:var(--sh1);transition:transform var(--dur) var(--ease)}
.act-photo:hover{transform:scale(1.03)}
.act-photo img{width:100%;height:180px;object-fit:cover}
.act-photo.tall img{height:244px}
.act-photo.full{grid-column:span 2}
.act-photo.full img{height:200px}

.act-list{display:flex;flex-direction:column;gap:14px;margin-top:28px}
.act-item{
  display:flex;align-items:flex-start;gap:14px;
  background:var(--wh);padding:18px 20px;border-radius:var(--r2);
  box-shadow:var(--sh1);transition:transform var(--dur) var(--ease);
}
.act-item:hover{transform:translateX(5px)}
.act-ico{
  font-size:24px;flex-shrink:0;
  width:48px;height:48px;background:var(--g5);border-radius:var(--r2);
  display:flex;align-items:center;justify-content:center;
}
.act-t{font-size:15px;font-weight:700;color:var(--txt);margin-bottom:3px}
.act-d{font-size:13px;color:var(--txt3);line-height:1.6}

/* ============================================================
   イベント
   ============================================================ */
#events{background:var(--wh)}

.ev-hero{
  border-radius:var(--r3);overflow:hidden;
  box-shadow:var(--sh2);margin-bottom:48px;
}
.ev-hero img{width:100%;height:360px;object-fit:cover;object-position:center 30%}

.ev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ev-card{
  background:var(--g5);border-radius:var(--r2);padding:24px 22px;
  text-align:center;border:2px solid transparent;
  transition:border-color var(--dur) var(--ease),transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.ev-card:hover{border-color:var(--g2);transform:translateY(-5px);box-shadow:var(--sh1)}
.ev-emoji{font-size:36px;margin-bottom:10px}
.ev-name{font-size:16px;font-weight:900;color:var(--g1);margin-bottom:7px}
.ev-desc{font-size:13px;color:var(--txt3);line-height:1.65}

/* ============================================================
   ご利用の流れ
   ============================================================ */
#flow{
  background:linear-gradient(135deg,#33691e 0%,#558b2f 100%);
}

.flow-steps{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:16px;margin-top:52px;position:relative;
}
.flow-steps::before{
  content:'';position:absolute;
  top:36px;left:10%;right:10%;
  height:2px;background:rgba(255,255,255,.25);
}
.flow-step{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;z-index:1;
}
.step-n{
  width:72px;height:72px;border-radius:50%;
  background:var(--wh);color:var(--g2);
  font-size:26px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;box-shadow:var(--sh2);flex-shrink:0;
}
.step-t{font-size:14px;font-weight:900;color:var(--wh);margin-bottom:8px}
.step-d{font-size:12px;color:rgba(255,255,255,.8);line-height:1.65}

.consultant-box{
  margin-top:60px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);
  border-radius:var(--r3);padding:32px 36px;
  display:flex;align-items:flex-start;gap:24px;flex-wrap:wrap;
}
.cb-ico{font-size:48px;flex-shrink:0}
.cb-body h3{font-size:18px;font-weight:900;color:var(--wh);margin-bottom:10px}
.cb-body p{font-size:14px;color:rgba(255,255,255,.82);line-height:1.8;margin-bottom:14px}
.cb-tags{display:flex;gap:10px;flex-wrap:wrap}
.cb-tag{
  background:rgba(255,255,255,.18);color:var(--wh);
  font-size:13px;font-weight:700;
  padding:7px 16px;border-radius:var(--r4);
}

/* ============================================================
   料金
   ============================================================ */
#pricing{background:var(--bg)}

.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.price-card{
  background:var(--wh);border-radius:var(--r3);padding:32px;
  box-shadow:var(--sh1);border-top:4px solid var(--g2);
}
.price-title{
  font-size:18px;font-weight:900;color:var(--g1);
  padding-bottom:16px;border-bottom:1px solid var(--bd);margin-bottom:20px;
}
.price-table{width:100%;border-collapse:collapse}
.price-table th,.price-table td{
  padding:11px 14px;font-size:14px;
  border-bottom:1px solid var(--bd);text-align:left;
}
.price-table th{background:var(--g5);color:var(--g1);font-weight:800}
.price-table td:last-child{font-weight:700;color:var(--g2)}
.price-note{
  font-size:12px;color:var(--txt3);line-height:1.75;margin-top:14px;
  background:var(--g5);border-radius:var(--r2);padding:12px 14px;
}

/* ============================================================
   施設・アクセス
   ============================================================ */
#facility{background:var(--wh)}

.fac-layout{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.fac-photos{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fac-photos img{border-radius:var(--r2);width:100%;height:180px;object-fit:cover;box-shadow:var(--sh1)}
.fac-photos img:first-child{grid-column:span 2;height:240px}

.info-box{background:var(--bg);border-radius:var(--r2);padding:24px;margin-bottom:20px}
.info-box-h{
  font-size:15px;font-weight:900;color:var(--g1);margin-bottom:14px;
  display:flex;align-items:center;gap:8px;
}
.info-row2{display:flex;gap:12px;padding:9px 0;border-bottom:1px solid var(--bd);font-size:14px}
.info-row2:last-child{border-bottom:none}
.info-key{flex-shrink:0;width:72px;color:var(--txt3);font-weight:700}
.info-val{color:var(--txt);line-height:1.65}
.tel-big{font-size:22px;font-weight:900;color:var(--g2)}

/* ============================================================
   お問い合わせ
   ============================================================ */
#contact{background:linear-gradient(160deg,#33691e 0%,#558b2f 100%)}

.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}

.contact-opts{display:flex;flex-direction:column;gap:14px}
.c-opt{
  display:flex;align-items:center;gap:18px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);
  border-radius:var(--r2);padding:22px 24px;
  transition:background var(--dur) var(--ease);
  text-decoration:none;
}
.c-opt:hover{background:rgba(255,255,255,.2);color:var(--wh)}
.c-opt-ico{font-size:32px;flex-shrink:0}
.c-opt-t{font-size:15px;font-weight:900;color:var(--wh);margin-bottom:3px}
.c-opt-s{font-size:13px;color:rgba(255,255,255,.7)}
.c-opt-tel{font-size:20px;font-weight:900;color:var(--g4)}

/* フォーム */
.c-form-wrap{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r3);padding:36px;
}
.c-form-h{font-size:18px;font-weight:900;color:var(--wh);margin-bottom:24px}
.fg{margin-bottom:18px}
.fg label{display:block;font-size:13px;font-weight:700;color:rgba(255,255,255,.85);margin-bottom:7px}
.fg input,.fg select,.fg textarea{
  width:100%;padding:11px 15px;
  background:rgba(255,255,255,.95);border:2px solid transparent;
  border-radius:var(--r2);font-size:14px;font-family:inherit;color:var(--txt);
  transition:border-color var(--dur) var(--ease);outline:none;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--g4)}
.fg textarea{min-height:96px;resize:vertical}
.c-submit{
  width:100%;padding:15px;
  background:var(--g3);color:var(--wh);border:none;
  border-radius:var(--r2);font-size:16px;font-weight:900;
  cursor:pointer;font-family:inherit;
  transition:background var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.c-submit:hover{background:var(--g2);transform:translateY(-2px)}
.form-ok{
  display:none;margin-top:14px;padding:14px;
  background:rgba(165,214,167,.2);border:1px solid var(--g4);
  border-radius:var(--r2);text-align:center;color:var(--wh);font-weight:700;
}

/* CF7 スタイル上書き */
.wpcf7-form .fg input,
.wpcf7-form .fg select,
.wpcf7-form .fg textarea{
  width:100%;padding:11px 15px;
  background:rgba(255,255,255,.95);border:2px solid transparent;
  border-radius:var(--r2);font-size:14px;font-family:inherit;color:var(--txt);
}
.wpcf7-submit{
  width:100%;padding:15px;
  background:var(--g3);color:var(--wh);border:none;
  border-radius:var(--r2);font-size:16px;font-weight:900;
  cursor:pointer;font-family:inherit;
  transition:background var(--dur) var(--ease);
}
.wpcf7-submit:hover{background:var(--g2)}
.wpcf7-response-output{margin-top:14px;padding:14px;border-radius:var(--r2);font-size:14px;}

/* ============================================================
   フッター
   ============================================================ */
#footer{background:#1a2e0a;color:rgba(255,255,255,.68);padding:52px 0 24px}
.ft-top{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;
  padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1);
  margin-bottom:28px;
}
.ft-brand .logo-name{color:var(--wh);font-size:20px;margin-bottom:10px}
.ft-brand p{font-size:13px;line-height:1.85}
.ft-col-h{font-size:14px;font-weight:900;color:var(--wh);margin-bottom:14px}
.ft-col a{
  display:block;font-size:13px;color:rgba(255,255,255,.6);
  padding:5px 0;transition:color var(--dur) var(--ease);
}
.ft-col a:hover{color:var(--wh)}
.ft-bottom{text-align:center;font-size:12px;color:rgba(255,255,255,.35)}

/* ============================================================
   固定CTAバー（スマホ）
   ============================================================ */
#fix-cta{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:800;
  background:var(--wh);border-top:1px solid var(--bd);
  padding:10px 14px max(10px,env(safe-area-inset-bottom));
}
.fix-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.fix-btn{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:9px 4px;border-radius:var(--r2);
  font-size:11px;font-weight:800;cursor:pointer;
  text-decoration:none;transition:opacity var(--dur) var(--ease);
}
.fix-btn:hover{opacity:.85}
.fix-tel{background:var(--g2);color:var(--wh)}
.fix-mail{background:var(--ora);color:var(--wh)}
.fix-visit{background:var(--g5);color:var(--g1);border:1px solid var(--bd)}

/* ============================================================
   最新情報バー（ヒーロー直下）
   ============================================================ */
#latest-bar {
  background: var(--wh);
  border-bottom: 1px solid var(--bd);
  box-shadow: 0 2px 12px rgba(106,180,46,.10);
}

.latest-inner {
  display: flex;
  align-items: center;
  gap: 0;
  max-width: 1160px;
  margin: 0 auto;
  min-height: 52px;
}

/* 「最新情報」ラベル */
.latest-label {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-shrink: 0;
  background: var(--g2);
  color: var(--wh);
  font-size: 13px;
  font-weight: 900;
  padding: 0 22px;
  height: 52px;
  letter-spacing: .05em;
  white-space: nowrap;
}

/* スクロールトラック */
.latest-track-wrap {
  flex: 1;
  overflow: hidden;
  padding: 0 18px;
  position: relative;
}
/* 左右フェードマスク */
.latest-track-wrap::before,
.latest-track-wrap::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 24px;
  pointer-events: none;
  z-index: 1;
}
.latest-track-wrap::before {
  left: 0;
  background: linear-gradient(to right, var(--wh), transparent);
}
.latest-track-wrap::after {
  right: 0;
  background: linear-gradient(to left, var(--wh), transparent);
}

.latest-track {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 0;
  margin: 0;
  list-style: none;
}

.latest-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--bg);
  flex-wrap: nowrap;
  overflow: hidden;
}
.latest-item:last-child {
  border-bottom: none;
}

.latest-date {
  font-size: 12px;
  font-weight: 700;
  color: var(--txt3);
  white-space: nowrap;
  flex-shrink: 0;
}

.latest-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 800;
  padding: 2px 9px;
  border-radius: var(--r4);
  white-space: nowrap;
  flex-shrink: 0;
  background: var(--g5);
  color: var(--g2);
}
.latest-badge.cat-event   { background: #fff4e5; color: #e07800; }
.latest-badge.cat-info    { background: #e8f4fd; color: #0078c8; }
.latest-badge.cat-program { background: var(--g5); color: var(--g2); }

.latest-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--txt);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: color var(--dur) var(--ease);
  flex: 1;
  min-width: 0;
}
.latest-title:hover { color: var(--g2); }

/* 「一覧」ボタン */
.latest-more {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
  font-size: 12px;
  font-weight: 800;
  color: var(--g2);
  padding: 0 20px;
  height: 52px;
  border-left: 1px solid var(--bd);
  white-space: nowrap;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.latest-more:hover {
  background: var(--g5);
  color: var(--g1);
}

/* ── レスポンシブ ── */
@media (max-width: 768px) {
  .latest-inner {
    min-height: auto;
    flex-wrap: wrap;
  }
  .latest-label {
    width: 100%;
    height: 38px;
    padding: 0 16px;
    font-size: 12px;
  }
  .latest-track-wrap {
    flex: 1;
    padding: 4px 12px;
  }
  .latest-item {
    gap: 8px;
    padding: 9px 0;
  }
  .latest-more {
    height: 38px;
    padding: 0 14px;
    border-left: 1px solid var(--bd);
  }
}

@media (max-width: 480px) {
  .latest-date { display: none; }
  .latest-title { font-size: 12px; }
}

/* ============================================================
   お知らせ（NEWS）セクション
   ============================================================ */
#news { background: var(--wh); }

/* カテゴリーバッジ */
.news-cat-badge {
  display: inline-block;
  font-size: 11px; font-weight: 800; letter-spacing: .08em;
  padding: 3px 12px; border-radius: var(--r4);
  background: var(--g5); color: var(--g2);
  white-space: nowrap;
}
.news-cat-badge.cat-event   { background: #fff4e5; color: #e07800; }
.news-cat-badge.cat-info    { background: #e8f4fd; color: #0078c8; }
.news-cat-badge.cat-program { background: var(--g5); color: var(--g2); }

/* 一覧グリッド */
.news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
}

/* カード */
.news-card {
  background: var(--wh);
  border-radius: var(--r2);
  box-shadow: var(--sh1);
  overflow: hidden;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  display: flex; flex-direction: column;
}
.news-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--sh2);
}
.news-card a { color: inherit; text-decoration: none; display: flex; flex-direction: column; height: 100%; }

/* サムネイル */
.news-thumb {
  position: relative;
  height: 200px; overflow: hidden;
  background: var(--bg);
}
.news-thumb img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .5s var(--ease);
}
.news-card:hover .news-thumb img { transform: scale(1.07); }

/* サムネイルなし時のプレースホルダー */
.news-thumb-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg); color: var(--g4); font-size: 48px;
}

/* カード本文 */
.news-body {
  padding: 20px 22px 24px;
  display: flex; flex-direction: column; flex: 1;
}
.news-meta {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 10px; flex-wrap: wrap;
}
.news-date {
  font-size: 12px; color: var(--txt3); font-weight: 700;
}
.news-title {
  font-size: 15px; font-weight: 700; color: var(--txt);
  line-height: 1.6; margin-bottom: 10px;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
.news-excerpt {
  font-size: 13px; color: var(--txt3); line-height: 1.7;
  display: -webkit-box; -webkit-line-clamp: 3;
  -webkit-box-orient: vertical; overflow: hidden;
  flex: 1;
}
.news-more {
  display: inline-flex; align-items: center; gap: 5px;
  margin-top: 14px; font-size: 13px; font-weight: 700;
  color: var(--g2);
}
.news-more i { font-size: 11px; }

/* 全件リンク */
.news-footer {
  text-align: center;
  margin-top: 44px;
}
.btn-outline {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 36px; border-radius: var(--r4);
  border: 2px solid var(--g2); color: var(--g2);
  font-size: 14px; font-weight: 800;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.btn-outline:hover { background: var(--g2); color: var(--wh); }

/* 記事なし時 */
.news-empty {
  text-align: center; padding: 60px 0;
  color: var(--txt3); font-size: 15px;
}

/* ── wp_nav_menu() が生成する <ul> のスタイル調整 ── */
/* グローバルナビ */
#gnav > ul { display: flex; gap: 2px; }
#gnav > ul li a {
  display: block; padding: 7px 13px; border-radius: var(--r4);
  font-size: 13px; font-weight: 700; color: var(--txt2);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
#gnav > ul li a:hover { background: var(--g5); color: var(--g2); }

/* モバイルメニュー */
#mob-menu > ul li a {
  display: block; padding: 14px 4px; border-bottom: 1px solid var(--bd);
  font-size: 16px; font-weight: 700; color: var(--txt);
}

/* フッターナビ */
.ft-col ul { list-style: none; padding: 0; margin: 0; }
.ft-col ul li a {
  display: block; font-size: 13px; color: rgba(255,255,255,.6);
  padding: 5px 0; transition: color var(--dur) var(--ease);
}
.ft-col ul li a:hover { color: var(--wh); }

/* ============================================================
   レスポンシブ
   ============================================================ */
@media(max-width:1024px){
  .about-grid,.sch-layout,.act-layout,.fac-layout,
  .contact-layout,.price-grid,.svc-grid{grid-template-columns:1fr}
  .news-grid{grid-template-columns:repeat(2,1fr)}
  .about-img-sub{display:none}
  .about-img-main{height:320px}
  .flow-steps{grid-template-columns:repeat(3,1fr)}
  .flow-steps::before{display:none}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-item:nth-child(1){grid-column:span 1;grid-row:span 1}
  .hero-stats{display:none}
  .transfer-banner{flex-direction:column}
  .btn-white{margin-left:0;width:100%;justify-content:center}
}

@media(max-width:768px){
  html{font-size:14px}
  .section-pad{padding:64px 0}
  #gnav,.hdr-cta{display:none}
  #ham{display:flex}
  #hero{height:80vh}
  .hero-body{padding:0 20px 88px}
  .hero-btns{flex-direction:column}
  .btn-prim,.btn-ghost{width:100%;justify-content:center}
  .tbar-inner{grid-template-columns:1fr}
  .tbar-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.15)}
  .gallery-grid{
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto;
  }
  .gallery-grid .gallery-item{height:140px}
  .ev-grid{grid-template-columns:repeat(2,1fr)}
  .flow-steps{grid-template-columns:1fr}
  .ft-top{grid-template-columns:1fr;gap:28px}
  .act-photos{grid-template-columns:1fr}
  .act-photo.full{grid-column:1}
  #fix-cta{display:block}
  body{padding-bottom:72px}
  .sch-tabs{overflow-x:auto}
}

@media(max-width:768px){
  .news-grid{grid-template-columns:1fr}
}

@media(max-width:480px){
  .ev-grid,.price-grid{grid-template-columns:1fr}
  .hero-h1{font-size:28px}
  .consultant-box{flex-direction:column}
}

/* ============================================================
   内部ページ共通（single / page / archive）
   ============================================================ */

/* ── ページヒーロー ── */
.inner-hero {
  margin-top: 64px; /* 固定ヘッダー分 */
  background: linear-gradient(135deg, var(--g1) 0%, var(--g2) 100%);
  padding: 52px 0 44px;
}
.inner-hero .breadcrumb {
  display: flex; align-items: center; flex-wrap: wrap; gap: 6px;
  font-size: 13px; color: rgba(255,255,255,.7);
  margin-bottom: 16px;
}
.inner-hero .breadcrumb a {
  color: rgba(255,255,255,.8);
  transition: color var(--dur) var(--ease);
}
.inner-hero .breadcrumb a:hover { color: var(--wh); }
.bc-sep { font-size: 10px; opacity: .6; }
.bc-current { color: var(--wh); font-weight: 700; }

.inner-page-title {
  font-size: clamp(22px, 3.5vw, 36px);
  font-weight: 900; color: var(--wh);
  line-height: 1.3;
  text-shadow: 0 2px 12px rgba(0,0,0,.2);
}

/* ── ページ本体ラッパー ── */
.inner-wrap { padding: 64px 0 96px; }

/* ── 2カラム レイアウト ── */
.inner-layout {
  display: grid;
  gap: 48px;
}
.inner-layout.has-sidebar {
  grid-template-columns: 1fr 300px;
}
.inner-layout.no-sidebar {
  grid-template-columns: 1fr;
  max-width: 860px;
  margin: 0 auto;
}

/* ── 記事本体 ── */
.inner-article {}

/* メタ情報（日付・カテゴリー） */
.article-meta {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 2px solid var(--bd);
}
.article-meta time {
  font-size: 13px; color: var(--txt3); font-weight: 700;
  display: flex; align-items: center; gap: 6px;
}

/* アイキャッチ画像 */
.article-thumb {
  border-radius: var(--r3); overflow: hidden;
  box-shadow: var(--sh2); margin-bottom: 36px;
}
.article-thumb img {
  width: 100%; height: auto; display: block;
}

/* ── 本文エリア (entry-content) ── */
.entry-content {
  font-size: 16px; color: var(--txt); line-height: 1.9;
}
.entry-content h2 {
  font-size: clamp(20px, 2.8vw, 26px); font-weight: 900;
  color: var(--g1); margin: 48px 0 18px;
  padding-left: 16px;
  border-left: 5px solid var(--g2);
  line-height: 1.4;
}
.entry-content h3 {
  font-size: clamp(17px, 2.2vw, 21px); font-weight: 800;
  color: var(--g1); margin: 36px 0 14px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--bd);
}
.entry-content h4 {
  font-size: 16px; font-weight: 800;
  color: var(--txt); margin: 28px 0 10px;
}
.entry-content p {
  margin-bottom: 1.6em;
}
.entry-content a {
  color: var(--g2); text-decoration: underline;
  text-underline-offset: 3px;
}
.entry-content a:hover { color: var(--g1); }
.entry-content ul, .entry-content ol {
  padding-left: 1.5em; margin-bottom: 1.4em;
}
.entry-content ul li { list-style: disc; margin-bottom: .5em; }
.entry-content ol li { list-style: decimal; margin-bottom: .5em; }
.entry-content blockquote {
  background: var(--bg); border-left: 4px solid var(--g3);
  padding: 16px 20px; border-radius: 0 var(--r2) var(--r2) 0;
  margin: 24px 0; color: var(--txt2); font-style: italic;
}
.entry-content img {
  border-radius: var(--r2); box-shadow: var(--sh1);
  max-width: 100%; height: auto; margin: 8px 0;
}
.entry-content table {
  width: 100%; border-collapse: collapse; margin-bottom: 1.4em;
  font-size: 14px;
}
.entry-content table th,
.entry-content table td {
  padding: 10px 14px; border: 1px solid var(--bd); text-align: left;
}
.entry-content table th {
  background: var(--g5); font-weight: 800; color: var(--g1);
}
.entry-content figure { margin: 24px 0; }
.entry-content figcaption {
  font-size: 12px; color: var(--txt3); text-align: center; margin-top: 6px;
}
/* WPブロック：ボタン */
.entry-content .wp-block-button__link {
  background: var(--g2); color: var(--wh) !important;
  padding: 12px 28px; border-radius: var(--r4);
  font-weight: 800; text-decoration: none;
  transition: background var(--dur) var(--ease);
}
.entry-content .wp-block-button__link:hover { background: var(--g1); }
/* WPブロック：区切り線 */
.entry-content hr { border: none; border-top: 2px solid var(--bd); margin: 36px 0; }
/* WPブロック：カバー */
.entry-content .wp-block-cover { border-radius: var(--r2); overflow: hidden; }

/* ── 前後記事ナビ ── */
.post-nav { margin-top: 52px; padding-top: 36px; border-top: 2px solid var(--bd); }
.post-nav-inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 12px; align-items: center;
}
.post-nav-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 16px; border-radius: var(--r2);
  font-size: 13px; font-weight: 700; color: var(--g2);
  background: var(--bg);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
  text-decoration: none;
}
.post-nav-btn:hover { background: var(--g5); color: var(--g1); }
.post-nav-btn.disabled { opacity: 0; pointer-events: none; }
.post-nav-prev { justify-content: flex-start; }
.post-nav-prev span { overflow: hidden; display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; }
.post-nav-next { justify-content: flex-end; text-align: right; }
.post-nav-next span { overflow: hidden; display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; }
.post-nav-list {
  flex-shrink: 0; background: var(--g2); color: var(--wh);
  padding: 12px 20px; justify-content: center;
}
.post-nav-list:hover { background: var(--g1); color: var(--wh); }

/* ============================================================
   ウィジェットサイドバー
   ============================================================ */
.inner-sidebar {
  display: flex; flex-direction: column; gap: 28px;
}

/* 共通ウィジェット枠 */
.inner-sidebar .widget {
  background: var(--wh);
  border-radius: var(--r2);
  box-shadow: var(--sh1);
  padding: 24px 22px;
  overflow: hidden;
}

/* ウィジェットタイトル */
.inner-sidebar .widget-title {
  font-size: 14px; font-weight: 900; color: var(--g1);
  margin-bottom: 16px; padding-bottom: 10px;
  border-bottom: 2px solid var(--bd);
  display: flex; align-items: center; gap: 8px;
}
.inner-sidebar .widget-title::before {
  content: ''; display: block;
  width: 4px; height: 16px;
  background: var(--g2); border-radius: 2px;
  flex-shrink: 0;
}

/* テキストウィジェット */
.inner-sidebar .textwidget {
  font-size: 13px; color: var(--txt2); line-height: 1.8;
}
.inner-sidebar .textwidget a { color: var(--g2); }
.inner-sidebar .textwidget a:hover { color: var(--g1); }

/* 最近の投稿ウィジェット */
.inner-sidebar .widget_recent_entries ul { padding: 0; margin: 0; }
.inner-sidebar .widget_recent_entries ul li {
  padding: 9px 0; border-bottom: 1px solid var(--bd);
  font-size: 13px; line-height: 1.55;
}
.inner-sidebar .widget_recent_entries ul li:last-child { border-bottom: none; }
.inner-sidebar .widget_recent_entries ul li a {
  color: var(--txt); display: block;
  transition: color var(--dur) var(--ease);
}
.inner-sidebar .widget_recent_entries ul li a:hover { color: var(--g2); }
.inner-sidebar .widget_recent_entries .post-date {
  font-size: 11px; color: var(--txt3); font-weight: 700; margin-top: 3px; display: block;
}

/* カテゴリーウィジェット */
.inner-sidebar .widget_categories ul { padding: 0; margin: 0; }
.inner-sidebar .widget_categories ul li {
  padding: 8px 0; border-bottom: 1px solid var(--bd);
  font-size: 13px;
}
.inner-sidebar .widget_categories ul li:last-child { border-bottom: none; }
.inner-sidebar .widget_categories ul li a {
  color: var(--txt2); display: flex; align-items: center; gap: 6px;
  transition: color var(--dur) var(--ease);
}
.inner-sidebar .widget_categories ul li a::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--g3); flex-shrink: 0;
}
.inner-sidebar .widget_categories ul li a:hover { color: var(--g2); }
.inner-sidebar .widget_categories .children { padding-left: 16px; margin-top: 4px; }

/* アーカイブウィジェット */
.inner-sidebar .widget_archive ul { padding: 0; margin: 0; }
.inner-sidebar .widget_archive ul li {
  padding: 8px 0; border-bottom: 1px solid var(--bd); font-size: 13px;
}
.inner-sidebar .widget_archive ul li:last-child { border-bottom: none; }
.inner-sidebar .widget_archive ul li a {
  color: var(--txt2); transition: color var(--dur) var(--ease);
}
.inner-sidebar .widget_archive ul li a:hover { color: var(--g2); }

/* タグクラウドウィジェット */
.inner-sidebar .widget_tag_cloud .tagcloud {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.inner-sidebar .widget_tag_cloud .tagcloud a {
  display: inline-block; padding: 4px 12px;
  background: var(--g5); color: var(--g2);
  border-radius: var(--r4); font-size: 12px !important; font-weight: 700;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.inner-sidebar .widget_tag_cloud .tagcloud a:hover {
  background: var(--g2); color: var(--wh);
}

/* 検索ウィジェット */
.inner-sidebar .widget_search .search-form {
  display: flex; gap: 8px;
}
.inner-sidebar .widget_search .search-field {
  flex: 1; padding: 9px 12px; border: 2px solid var(--bd);
  border-radius: var(--r2); font-size: 13px; font-family: inherit;
  outline: none; color: var(--txt);
  transition: border-color var(--dur) var(--ease);
}
.inner-sidebar .widget_search .search-field:focus { border-color: var(--g2); }
.inner-sidebar .widget_search .search-submit {
  padding: 9px 14px; background: var(--g2); color: var(--wh);
  border: none; border-radius: var(--r2); cursor: pointer;
  font-size: 13px; font-weight: 800;
  transition: background var(--dur) var(--ease);
}
.inner-sidebar .widget_search .search-submit:hover { background: var(--g1); }

/* カスタムHTMLウィジェット */
.inner-sidebar .widget_custom_html {
  font-size: 13px; color: var(--txt2); line-height: 1.8;
}

/* ============================================================
   アーカイブページ（一覧）追加スタイル
   ============================================================ */

/* カテゴリーフィルターボタン */
.archive-filter {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 36px;
}
.filter-btn {
  display: inline-block; padding: 7px 18px;
  border-radius: var(--r4); font-size: 13px; font-weight: 700;
  background: var(--bg); color: var(--txt3);
  border: 2px solid var(--bd);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
  text-decoration: none; cursor: pointer;
}
.filter-btn:hover,
.filter-btn.active {
  background: var(--g2); color: var(--wh); border-color: var(--g2);
}
.filter-btn.cat-event.active  { background: #e07800; border-color: #e07800; }
.filter-btn.cat-info.active   { background: #0078c8; border-color: #0078c8; }

/* アーカイブグリッド（少し余白を調整） */
.archive-grid { margin-top: 0; }

/* ページネーション */
.archive-pagination {
  margin-top: 52px; display: flex; justify-content: center;
}
.archive-pagination .page-numbers {
  display: flex; flex-wrap: wrap; gap: 6px; padding: 0; list-style: none;
}
.archive-pagination .page-numbers li {}
.archive-pagination .page-numbers a,
.archive-pagination .page-numbers span {
  display: flex; align-items: center; justify-content: center;
  width: 42px; height: 42px; border-radius: var(--r2);
  font-size: 14px; font-weight: 700;
  background: var(--bg); color: var(--txt2);
  border: 2px solid var(--bd); text-decoration: none;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.archive-pagination .page-numbers a:hover {
  background: var(--g2); color: var(--wh); border-color: var(--g2);
}
.archive-pagination .page-numbers .current {
  background: var(--g2); color: var(--wh); border-color: var(--g2);
}
.archive-pagination .page-numbers .prev,
.archive-pagination .page-numbers .next {
  width: auto; padding: 0 16px; gap: 6px;
}

/* ============================================================
   フッターウィジェットエリア
   ============================================================ */
/* フッター内ウィジェットのスタイル統一 */
#footer .widget-title {
  font-size: 14px; font-weight: 900; color: var(--wh);
  margin-bottom: 14px;
}
#footer .widget {
  font-size: 13px; color: rgba(255,255,255,.65); line-height: 1.85;
}
#footer .widget a { color: rgba(255,255,255,.65); transition: color var(--dur) var(--ease); }
#footer .widget a:hover { color: var(--wh); }
#footer .widget ul { padding: 0; margin: 0; list-style: none; }
#footer .widget ul li { padding: 5px 0; }
#footer .widget ul li a { display: block; }
/* フッター検索 */
#footer .widget_search .search-form { display: flex; gap: 6px; }
#footer .widget_search .search-field {
  flex: 1; padding: 8px 10px; border-radius: var(--r2);
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(255,255,255,.1); color: var(--wh); font-size: 13px;
  outline: none;
}
#footer .widget_search .search-submit {
  padding: 8px 12px; background: var(--g3); color: var(--wh);
  border: none; border-radius: var(--r2); cursor: pointer;
  font-size: 13px;
}

/* ============================================================
   内部ページ レスポンシブ
   ============================================================ */
@media (max-width: 1024px) {
  .inner-layout.has-sidebar {
    grid-template-columns: 1fr;
  }
  .inner-sidebar {
    /* サイドバーを本文の下に */
    order: 2;
  }
  .inner-main { order: 1; }
}

@media (max-width: 768px) {
  .inner-hero { padding: 36px 0 28px; }
  .inner-page-title { font-size: 22px; }
  .inner-wrap { padding: 40px 0 72px; }
  .post-nav-inner { grid-template-columns: 1fr; gap: 8px; }
  .post-nav-prev, .post-nav-next, .post-nav-list { justify-content: center; }
  .post-nav-btn.disabled { display: none; }
}
