/* ============================================================
   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;
}

/* ============================================================
   フッター
   ============================================================ */
#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)}

/* ============================================================
   レスポンシブ
   ============================================================ */
@media(max-width:1024px){
  .about-grid,.sch-layout,.act-layout,.fac-layout,
  .contact-layout,.price-grid,.svc-grid{grid-template-columns: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:480px){
  .ev-grid,.price-grid{grid-template-columns:1fr}
  .hero-h1{font-size:28px}
  .consultant-box{flex-direction:column}
}
