/* ============================================================
   株式会社スペースリペア（会社サイト）— editorial / きちんとした
   方針：カード並べ・数字バンド・色帯CTAなし。交互レイアウト＋
   タイポ階層＋ヘアライン＋余白。意図あるタイポで“ちゃんとした”印象。
   ============================================================ */
:root{
  --paper:#FFFFFF; --ink:#181F1B; --sub:#5A675F; --line:#E3E7E1; --line-d:#CDD4CC;
  --green:#1C5E3E; --green-2:#2A7D52; --warm:#9A7A45;
  --head:"Zen Kaku Gothic New",-apple-system,sans-serif;
  --body:"Noto Sans JP",-apple-system,sans-serif;
  --maxw:1200px;
}
*{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 32px}
h1,h2,h3{font-family:var(--head);font-weight:700;margin:0;line-height:1.34;letter-spacing:.01em}
.kicker{font-family:var(--head);font-size:12px;font-weight:700;letter-spacing:.24em;color:var(--green);margin:0 0 22px;text-transform:uppercase}
.sub{color:var(--sub);font-size:16px;max-width:60ch}
.link-arrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--head);font-weight:700;font-size:14px;
  color:var(--ink);border-bottom:2px solid var(--green);padding-bottom:5px;transition:gap .2s,color .2s}
.link-arrow:hover{gap:15px;color:var(--green)}
.ph{background:repeating-linear-gradient(45deg,#ECEEE9 0 18px,#F3F4F0 18px 36px);
  display:grid;place-items:center;color:#9AA398;font-size:12.5px;width:100%;height:100%;min-height:260px}
.ph::after{content:"写真をここに（後で差し替え）"}

/* ---------- ローディング ---------- */
.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(19px,3.6vw,26px);letter-spacing:.14em}
.loader .ls{font-size:10px;letter-spacing:.42em;color:var(--green);margin-top:13px}
.loader .lb{width:1px;height:34px;background:var(--line-d);margin:20px auto 0;position:relative;overflow:hidden}
.loader .lb::before{content:"";position:absolute;inset:0;background:var(--green);transform:translateY(-100%);animation:lbar 1.2s 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:translateY(-100%)}60%,100%{transform:translateY(100%)}}

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

/* ---------- ヒーロー（非対称） ---------- */
.hero{border-bottom:1px solid var(--line)}
.hero .wrap{display:grid;grid-template-columns:minmax(0,48fr) minmax(0,52fr);gap:clamp(28px,3.5vw,56px);align-items:stretch;min-height:min(80vh,680px)}
.hero-text{padding:clamp(40px,6vw,80px) 0;display:flex;flex-direction:column;justify-content:center}
.hero h1{font-size:clamp(30px,3.8vw,46px);line-height:1.52;letter-spacing:.02em}
.hero .sub{margin:28px 0 36px}
.hero-img{position:relative;display:flex;margin-right:calc((100vw - min(100vw,var(--maxw)))/-2)}
.hero-img .ph{flex:1;height:100%;min-height:clamp(420px,56vh,640px)}

/* ---------- 交互フィーチャー（介護タクシー） ---------- */
.feature{border-bottom:1px solid var(--line)}
.feature .wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,80px);align-items:center;padding:clamp(64px,8vw,120px) 32px}
.feature-img .ph{min-height:clamp(320px,38vw,480px);border-radius:0}
.feature-text .num{font-family:var(--head);font-weight:700;font-size:13px;color:var(--green);letter-spacing:.1em}
.feature-text h2{font-size:clamp(26px,3.4vw,40px);margin:14px 0 18px}
.feature-text .sub{margin-bottom:30px}

/* ---------- 事業インデックス（カードではなく一覧） ---------- */
.index{padding:clamp(64px,8vw,116px) 0;border-bottom:1px solid var(--line)}
.index ul{list-style:none;margin:30px 0 0;padding:0;border-top:1px solid var(--line)}
.index li{display:grid;grid-template-columns:64px 1fr auto;gap:24px;align-items:baseline;
  padding:26px 6px;border-bottom:1px solid var(--line);transition:background .25s}
.index li:hover{background:#FAFBF9}
.index .n{font-family:var(--head);font-weight:700;color:var(--green);font-size:15px}
.index .name{font-family:var(--head);font-weight:700;font-size:clamp(18px,2vw,23px)}
.index .name span{display:block;font-family:var(--body);font-weight:400;font-size:13.5px;color:var(--sub);margin-top:4px}
.index .st{font-size:11.5px;letter-spacing:.08em;color:var(--sub);border:1px solid var(--line-d);padding:5px 13px;white-space:nowrap}

/* ---------- 私たちについて（非対称・テキスト主体） ---------- */
.about{border-bottom:1px solid var(--line)}
.about .wrap{display:grid;grid-template-columns:minmax(0,52fr) minmax(0,48fr);gap:clamp(34px,5vw,80px);align-items:center;padding:clamp(64px,8vw,120px) 32px}
.about h2{font-size:clamp(24px,3vw,36px);margin-bottom:24px;line-height:1.5}
.about p{color:var(--sub);margin:0 0 18px;max-width:54ch}
.about .ph{min-height:clamp(340px,40vw,520px)}

/* ---------- 会社概要 ---------- */
.company{padding:clamp(64px,8vw,116px) 0;border-bottom:1px solid var(--line)}
.company h2{font-size:clamp(24px,3vw,36px);margin-bottom:8px}
.info{margin-top:36px;border-top:1px solid var(--ink)}
.info .row{display:grid;grid-template-columns:220px 1fr;gap:24px;padding:20px 4px;border-bottom:1px solid var(--line);font-size:15px}
.info dt{margin:0;color:var(--sub);font-family:var(--head);font-weight:700;letter-spacing:.04em}
.info dd{margin:0}

/* ---------- お問い合わせ（色帯なし・editorial） ---------- */
.contact{padding:clamp(70px,9vw,128px) 0}
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end}
.contact h2{font-size:clamp(28px,3.6vw,44px);line-height:1.4}
.contact .tel{font-family:var(--head);font-weight:700;font-size:clamp(30px,4vw,48px);color:var(--green);letter-spacing:.03em;display:inline-block;margin:6px 0 4px}
.contact .meta{color:var(--sub);font-size:14px}
.contact .acts{display:flex;flex-direction:column;gap:14px}
.contact .acts a{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding:18px 2px;font-family:var(--head);font-weight:700}
.contact .acts a:last-child{border-bottom:1px solid var(--line)}
.contact .acts a::after{content:"→";color:var(--green)}

/* ---------- フッター ---------- */
.foot{border-top:1px solid var(--ink);padding:54px 0 30px}
.foot .wrap{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot .fb{font-family:var(--head);font-weight:700;font-size:17px;letter-spacing:.06em}
.foot .fa{font-size:13px;color:var(--sub);margin-top:12px;line-height:1.9}
.foot .fl{display:flex;gap:26px;flex-wrap:wrap;font-size:13px;color:var(--sub)}
.foot .cp{width:100%;border-top:1px solid var(--line);margin-top:34px;padding-top:18px;font-size:11.5px;color:#9AA398}

/* ---------- 出現 ---------- */
[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,.feature .wrap,.about .wrap,.contact .wrap{grid-template-columns:1fr}
  .hero .wrap{min-height:0}
  .hero-text{padding:48px 0 40px}
  .hero-img{margin:0 calc((100vw - min(100vw,100%))/-2)}
  .hero-img .ph,.feature-img .ph,.about .ph{min-height:300px}
  .feature-img{order:-1}
  .about .ph{order:-1}
  .menu{position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:var(--paper);
    border-bottom:1px solid var(--line);padding:8px 32px 20px;transform:translateY(-150%);transition:transform .3s}
  .menu.open{transform:none}
  .menu a{padding:15px 0;border-bottom:1px solid var(--line);font-size:15px}
  .burger{display:block}
  .index li{grid-template-columns:40px 1fr;gap:14px}
  .index .st{display:none}
  .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}
}
