/* ============================================================
   ライフスペースケアタクシー（介護タクシー・多ページ）
   白 × フレッシュ緑 × 丸ゴシック。親しみ・あたたかい・清潔・安心。
   カード並べでなく、編集的（交互レイアウト／一覧／余白）。
   ============================================================ */
:root{
  --paper:#FFFFFF; --soft:#F2FAF5; --ink:#152A1E; --sub:#506B5B; --line:#DDEEE3; --line-d:#C5E0CF;
  --green:#13A75A; --green-d:#0E8C4A; --green-deep:#0C3D24; --mint:#E7F7EE; --warm:#E8A23E;
  --head:"Zen Maru Gothic",-apple-system,sans-serif;
  --body:"Zen Maru Gothic","Noto Sans JP",-apple-system,sans-serif;
  --maxw:1140px; --r:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--body);font-size:16px;
  line-height:1.95;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
h1,h2,h3{font-family:var(--head);font-weight:700;margin:0;line-height:1.5;letter-spacing:.01em}
.kicker{font-family:var(--head);font-weight:700;font-size:12.5px;letter-spacing:.18em;color:var(--green);margin:0 0 16px}
.sub{color:var(--sub);font-size:16px;max-width:60ch}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--head);font-weight:700;font-size:14.5px;
  border-radius:999px;padding:15px 30px;transition:transform .2s,background .2s,box-shadow .2s}
.btn-green{background:var(--green);color:#fff;box-shadow:0 12px 26px rgba(19,167,90,.22)}
.btn-green:hover{background:var(--green-d);transform:translateY(-2px)}
.btn-ghost{border:1.5px solid var(--line-d);color:var(--ink)}
.btn-ghost:hover{border-color:var(--green);color:var(--green-d)}

/* ローダー */
.loader{position:fixed;inset:0;z-index:1000;background:var(--paper);display:grid;place-items:center;transition:opacity .7s,visibility .7s}
.loader .li{text-align:center;opacity:0;transform:translateY(8px);animation:lin 1s .1s forwards}
.loader .ln{font-family:var(--head);font-weight:700;font-size:clamp(18px,3.4vw,24px);letter-spacing:.08em;color:var(--green-d)}
.loader .ls{font-size:10px;letter-spacing:.4em;color:var(--sub);margin-top:12px}
.loader .lb{width:54px;height:3px;background:var(--mint);border-radius:3px;margin:18px auto 0;overflow:hidden}
.loader .lb::before{content:"";display:block;width:42%;height:100%;background:var(--green);border-radius:3px;animation:lbar 1.1s ease-in-out infinite}
html.is-loading{overflow:hidden}html:not(.is-loading) .loader{opacity:0;visibility:hidden}
@keyframes lin{to{opacity:1;transform:none}}@keyframes lbar{0%{transform:translateX(-130%)}100%{transform:translateX(330%)}}

/* ヘッダー */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:18px}
.brand{display:flex;align-items:center;gap:12px}
.logo-slot{width:42px;height:42px;border:1.5px dashed var(--line-d);border-radius:13px;display:grid;place-items:center;font-size:8.5px;color:#8FB7A0;text-align:center;line-height:1.1}
.bn{font-family:var(--head);font-weight:700;font-size:15.5px;letter-spacing:.04em}
.bn small{display:block;font-family:var(--body);font-weight:500;font-size:9.5px;letter-spacing:.18em;color:var(--green-d);margin-top:1px}
.menu{display:flex;align-items:center;gap:24px}
.menu a{font-size:13px;color:var(--sub);transition:color .2s}.menu a:hover{color:var(--ink)}
.menu a.cur{color:var(--green-d)}
.menu .call{background:var(--green);color:#fff;border-radius:999px;padding:10px 18px;font-family:var(--head);font-weight:700;font-size:13px}
.burger{display:none;border:0;background:none;cursor:pointer;padding:8px}
.burger span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;border-radius:2px}

/* ヒーロー（トップ） */
.hero{background:var(--soft);border-bottom:1px solid var(--line);overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(28px,4vw,56px);align-items:center;padding:clamp(48px,7vw,92px) 28px}
.hero h1{font-size:clamp(32px,4.6vw,52px);line-height:1.42}
.hero h1 em{font-style:normal;color:var(--green-d)}
.hero .sub{margin:24px 0 34px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}
.hero-ph{border-radius:var(--r);overflow:hidden;background:repeating-linear-gradient(45deg,#E3F2E8 0 16px,#EDF7F0 16px 32px);
  min-height:clamp(320px,40vw,440px);display:grid;place-items:center;color:#8AA994;font-size:13px}
.hero-ph::after{content:"写真をここに（後で差し替え）"}

/* ページヘッダー（下層） */
.phead{background:var(--soft);border-bottom:1px solid var(--line);padding:clamp(44px,6vw,76px) 0}
.bcrumb{font-size:12.5px;color:var(--sub);margin:0 0 14px}.bcrumb a{color:var(--green-d)}
.phead h1{font-size:clamp(28px,3.8vw,42px)}
.phead p{color:var(--sub);margin:14px 0 0;max-width:60ch}

/* セクション */
.sec{padding:clamp(60px,8vw,108px) 0}
.sec.soft{background:var(--soft)}
h2.title{font-size:clamp(24px,3.2vw,36px);margin-bottom:12px}
.center{text-align:center}.center .sub{margin:0 auto}

/* メニュー一覧（トップ→各ページ） */
.menu-list{list-style:none;margin:40px 0 0;padding:0;border-top:1px solid var(--line)}
.menu-list a{display:grid;grid-template-columns:60px 1fr auto;gap:22px;align-items:center;
  padding:26px 8px;border-bottom:1px solid var(--line);transition:background .25s,padding .25s}
.menu-list a:hover{background:var(--mint);padding-left:18px}
.menu-list .n{font-family:var(--head);font-weight:700;color:var(--green);font-size:15px}
.menu-list .nm{font-family:var(--head);font-weight:700;font-size:clamp(18px,2vw,22px)}
.menu-list .nm span{display:block;font-family:var(--body);font-weight:400;font-size:13px;color:var(--sub);margin-top:3px}
.menu-list .ar{color:var(--green);font-size:18px}

/* 交互フィーチャー */
.alt{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px);align-items:center}
.alt .ph{border-radius:var(--r);background:repeating-linear-gradient(45deg,#E3F2E8 0 16px,#EDF7F0 16px 32px);
  min-height:clamp(300px,36vw,440px);display:grid;place-items:center;color:#8AA994;font-size:13px}
.alt .ph::after{content:"写真をここに（後で差し替え）"}
.alt h2{font-size:clamp(23px,2.8vw,32px);margin-bottom:16px}

/* チップ（サービス等） */
.chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.chip{background:#fff;border:1px solid var(--line);border-radius:999px;padding:11px 20px;font-size:14px;box-shadow:0 6px 16px rgba(12,61,36,.05)}

/* 料金表 */
.price{width:100%;border-collapse:collapse;margin-top:28px;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.price th,.price td{text-align:left;padding:17px 24px;border-bottom:1px solid var(--line);font-size:14.5px}
.price thead th{background:var(--green);color:#fff;font-family:var(--head)}
.price td:last-child,.price th:last-child{text-align:right;white-space:nowrap}
.price td:first-child{color:var(--sub)}.price tr:last-child td{border-bottom:0}
.note-s{font-size:12.5px;color:var(--sub);margin-top:14px}

/* 強み・特長（縦並びの行・カードでない） */
.points{margin-top:36px;border-top:1px solid var(--line)}
.point{display:grid;grid-template-columns:48px 1fr;gap:20px;padding:26px 6px;border-bottom:1px solid var(--line)}
.point .ic{font-family:var(--head);font-weight:700;color:var(--green);font-size:15px}
.point h3{font-size:18px;margin-bottom:6px}.point p{color:var(--sub);margin:0;font-size:14.5px}

/* ステップ */
.steps{margin-top:36px;border-top:1px solid var(--line)}
.stp{display:grid;grid-template-columns:60px 1fr;gap:20px;padding:24px 6px;border-bottom:1px solid var(--line)}
.stp .no{font-family:var(--head);font-weight:700;color:#fff;background:var(--green);width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-size:15px}
.stp h3{font-size:17px;margin-bottom:4px}.stp p{color:var(--sub);margin:0;font-size:14px}

/* 情報 */
.info{margin-top:32px;border-top:1px solid var(--ink)}
.info .row{display:grid;grid-template-columns:200px 1fr;gap:22px;padding:18px 4px;border-bottom:1px solid var(--line);font-size:15px}
.info dt{margin:0;color:var(--sub);font-family:var(--head);font-weight:700}.info dd{margin:0}

/* 代表挨拶 */
.msg{max-width:74ch}.msg p{color:#2E4A39;margin:0 0 18px}.msg .sign{font-family:var(--head);font-weight:700;margin-top:8px}

/* CTA（緑の帯・角丸） */
.cta{background:var(--green-deep);color:#fff;border-radius:var(--r);padding:clamp(40px,6vw,64px);text-align:center}
.cta h2{color:#fff;font-size:clamp(23px,3vw,34px)}
.cta p{color:rgba(255,255,255,.85);margin:12px 0 24px}
.cta .tel{font-family:var(--head);font-weight:700;font-size:clamp(28px,4vw,44px);color:#fff;letter-spacing:.03em;display:inline-block}
.cta .acts{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:10px}
.btn-white{background:#fff;color:var(--green-deep)}

/* フッター */
.foot{background:#0C3D24;color:#A9D2BC;padding:56px 0 30px}
.foot .cols{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot .fb{font-family:var(--head);font-weight:700;font-size:17px;color:#fff;letter-spacing:.04em}
.foot .fa{font-size:13px;margin-top:12px;line-height:1.9}
.foot a{color:#A9D2BC}.foot a:hover{color:#fff}
.foot .fl{display:flex;gap:22px;flex-wrap:wrap;font-size:13px}
.foot .cp{width:100%;border-top:1px solid rgba(255,255,255,.13);margin-top:32px;padding-top:18px;font-size:11.5px;color:#7FB397}

/* 出現 */
[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
[data-reveal].in{opacity:1;transform:none}.d1{transition-delay:.1s}.d2{transition-delay:.2s}

@media(max-width:880px){
  .hero .wrap,.alt{grid-template-columns:1fr}
  .alt .imgcol{order:-1}
  .menu{position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:#fff;border-bottom:1px solid var(--line);padding:8px 28px 18px;transform:translateY(-150%);transition:transform .3s}
  .menu.open{transform:none}
  .menu a{padding:14px 0;border-bottom:1px solid var(--line);font-size:15px}
  .menu .call{margin-top:12px;text-align:center}
  .burger{display:block}
  .menu-list a{grid-template-columns:40px 1fr auto;gap:14px}
  .info .row{grid-template-columns:1fr;gap:4px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}[data-reveal]{opacity:1;transform:none}html:not(.is-loading) .loader{display:none}}
