/* ============================================================
   株式会社スペースリペア — 会社トップ v9
   白基調 × 緑 × 本物の3D（モーフする光沢グラデの塊）
   ============================================================ */

:root{
  --bg:#f4f3ee;
  --s1:#ecebe4;
  --paper:#ffffff;
  --ink:#181a17;
  --ink2:#575a52;
  --ink3:#8e9187;
  --line:rgba(24,26,23,.12);
  --line2:rgba(24,26,23,.22);
  --acc:#1f9d63;
  --acc-d:#147a4a;
  --acc-l:#56d39a;
  --dark:#0f1411;
  --shadow:0 26px 64px rgba(20,40,30,.12),0 6px 18px rgba(20,40,30,.06);
  --shadow-sm:0 14px 36px rgba(20,40,30,.09);
  --disp:"Schibsted Grotesk","Zen Kaku Gothic New",system-ui,sans-serif;
  --jp:"Zen Kaku Gothic New","Noto Sans JP",system-ui,sans-serif;
  --body:"Noto Sans JP",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
  --gut:clamp(20px,4.6vw,76px);
  --max:1300px;
  --ease:cubic-bezier(.62,0,.1,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{background:var(--bg);-webkit-text-size-adjust:100%}
body{font-family:var(--body);background:var(--bg);color:var(--ink);font-size:15px;line-height:1.8;
  letter-spacing:.005em;overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
h1,h2,h3{font-family:var(--disp);font-weight:600;letter-spacing:-.02em;line-height:1.08;color:var(--ink);
  word-break:keep-all;overflow-wrap:normal}
::selection{background:var(--acc);color:#fff}
.mono{font-family:var(--mono);font-weight:400;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3)}
.grain{display:none}

.cursor{position:fixed;top:0;left:0;z-index:250;width:36px;height:36px;border:1px solid var(--acc);border-radius:50%;
  pointer-events:none;opacity:0;transition:opacity .3s ease,width .3s var(--ease),height .3s var(--ease),background .3s}
html.is-ready .cursor{opacity:1}
.cursor.is-hot{width:56px;height:56px;background:rgba(31,157,99,.1)}

.loader{position:fixed;inset:0;z-index:300;display:grid;place-items:center;gap:22px;background:var(--bg);
  transition:opacity .7s ease,visibility .7s ease}
html.is-ready .loader{opacity:0;visibility:hidden}
.loader-mark{font-family:var(--disp);font-weight:600;font-size:14px;letter-spacing:.18em;color:var(--ink);
  width:54px;height:54px;display:grid;place-items:center;border:1px solid var(--line2)}
.loader-bar{width:120px;height:1px;background:var(--line)}
.loader-bar i{display:block;height:100%;width:0;background:var(--acc);transition:width 1s var(--ease)}
html.is-ready .loader-bar i,.loader-bar.go i{width:100%}

/* header（写真上=白／スクロールで明ガラス＋黒文字） */
.head{position:fixed;inset:0 0 auto;z-index:120;display:flex;align-items:center;gap:24px;height:74px;padding:0 var(--gut);
  color:#fff;border-bottom:1px solid transparent;transition:color .4s ease,background .45s ease,border-color .45s ease,backdrop-filter .45s ease}
html.is-scrolled .head{color:var(--ink);background:rgba(244,243,238,.82);border-bottom-color:var(--line);backdrop-filter:blur(16px) saturate(1.1)}
.head-brand{display:flex;align-items:center;gap:10px;margin-right:auto}
.hb-mark{font-family:var(--disp);font-weight:600;font-size:12px;letter-spacing:.1em;width:32px;height:32px;display:grid;place-items:center;border:1px solid currentColor;opacity:.9}
.hb-txt{font-family:var(--disp);font-size:12px;letter-spacing:.18em;line-height:1.25}
.hb-txt em{display:block;font-family:var(--jp);font-style:normal;font-size:10px;letter-spacing:.04em;opacity:.62;margin-top:1px}
.head-nav{display:flex;gap:clamp(14px,1.8vw,28px)}
.head-nav a{font-family:var(--disp);font-size:12.5px;letter-spacing:.02em;opacity:.82;transition:opacity .25s}
.head-nav a:hover{opacity:1}
.head-tel{display:grid;line-height:1.15;text-align:right;padding-left:20px;margin-left:2px;border-left:1px solid currentColor}
.head-tel span{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;opacity:.6}
.head-tel b{font-family:var(--disp);font-weight:600;font-size:14px;letter-spacing:.01em}
.head-burger{display:none;width:40px;height:40px;background:none;border:0;cursor:pointer;flex-direction:column;gap:6px;align-items:flex-end;justify-content:center}
.head-burger i{display:block;height:1.5px;width:22px;background:currentColor;transition:transform .3s var(--ease),width .3s}
.head-burger i:last-child{width:15px}
html.nav-open .head-burger i:first-child{transform:translateY(3.75px) rotate(45deg);width:22px}
html.nav-open .head-burger i:last-child{transform:translateY(-3.75px) rotate(-45deg);width:22px}

.btn{display:inline-flex;align-items:center;gap:9px;height:50px;padding:0 24px;border-radius:7px;
  font-family:var(--disp);font-weight:500;font-size:13.5px;letter-spacing:.01em;border:1px solid transparent;
  transition:transform .4s var(--ease),background .3s,color .3s,border-color .3s}
.btn .ar{font-size:12px;transition:transform .35s var(--ease)}
.btn:hover .ar{transform:translate(3px,0)}
.btn-fill{background:var(--ink);color:#fff;box-shadow:0 14px 32px rgba(24,26,23,.18)}
.btn-fill:hover{background:var(--acc-d);transform:translateY(-2px)}
.btn-line{border-color:var(--line2);color:var(--ink)}
.btn-line:hover{border-color:var(--ink);background:rgba(24,26,23,.04)}

.wrap{max-width:var(--max);margin:0 auto;padding-inline:var(--gut)}
.sec-index{display:block;margin-bottom:clamp(22px,3vw,40px)}
[data-split] .l{display:block;overflow:hidden;padding-block:.04em}
[data-split] .li{display:block;will-change:transform}
.l em,.hero-h em{font-style:normal;color:var(--acc-d)}

/* ============ HERO（写真・パララックス） ============ */
.hero{position:relative;height:100svh;min-height:560px;overflow:hidden;color:#fff}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:50% 50%}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,11,11,.3) 0%,transparent 24%,transparent 48%,rgba(10,11,11,.6) 100%),
    radial-gradient(80% 60% at 16% 100%,rgba(10,11,11,.5),transparent 60%)}
.hero-inner{position:absolute;left:0;right:0;bottom:0;z-index:2;max-width:var(--max);margin:0 auto;
  padding:0 var(--gut) clamp(40px,6vw,86px);will-change:transform}
.hero-eyebrow{display:inline-flex;align-items:center;gap:11px;margin-bottom:18px;
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.hero-eyebrow::before{content:"";width:22px;height:1.5px;border-radius:2px;background:var(--acc-l)}
.hero-h{font-family:var(--jp);font-weight:900;color:#fff;font-size:clamp(34px,6vw,80px);line-height:1.08;letter-spacing:-.01em;text-shadow:0 2px 40px rgba(0,0,0,.35)}
.hero-h .sq{display:inline-block;width:.3em;height:.3em;margin-left:.14em;background:var(--acc-l);vertical-align:baseline}
.hero-sub{margin-top:clamp(16px,1.8vw,24px);max-width:46ch;color:rgba(255,255,255,.84);font-size:clamp(14px,1vw,16px);line-height:1.85;text-shadow:0 1px 20px rgba(0,0,0,.4)}
.hero-act{display:flex;flex-wrap:wrap;gap:11px;margin-top:clamp(22px,2.6vw,34px)}
.hero .btn-line{color:#fff;border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.06);backdrop-filter:blur(6px)}
.hero .btn-line:hover{border-color:#fff;background:rgba(255,255,255,.14)}
.hero-cta{position:absolute;right:var(--gut);bottom:clamp(40px,6vw,86px);z-index:3;
  width:clamp(64px,7vw,92px);height:clamp(64px,7vw,92px);border-radius:50%;display:grid;place-items:center;
  background:var(--acc);color:#fff;font-size:22px;box-shadow:0 18px 50px rgba(31,157,99,.4);will-change:transform;transition:background .3s}
.hero-cta:hover{background:var(--acc-d)}
.hero-scrollhint{position:absolute;left:var(--gut);bottom:clamp(18px,2.4vw,28px);z-index:3;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;color:rgba(255,255,255,.62)}

/* ============ sections ============ */
.philo{position:relative;background:var(--bg)}
.philo .wrap{padding-block:clamp(80px,10vw,150px)}
.philo .sec-index{color:var(--ink3)}
.philo-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,5vw,80px);align-items:end}
.philo-h{font-size:clamp(26px,3.8vw,50px);letter-spacing:-.02em;max-width:15ch}
.philo-h em{color:var(--acc-d)}
.philo-body p{color:var(--ink2);font-size:15px;line-height:2}
.philo-body p+p{margin-top:16px}
.philo-sign{margin-top:24px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3)}

.divisions{position:relative;background:var(--s1);border-top:1px solid var(--line)}
.div-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;
  padding-block:clamp(60px,8vw,108px) clamp(26px,3.4vw,46px)}
.div-title{font-size:clamp(25px,3.6vw,46px)}
.divisions .wrap{padding-bottom:clamp(40px,6vw,90px)}
.divrow{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(24px,4vw,64px);align-items:center;
  padding-block:clamp(30px,3.6vw,56px);border-top:1px solid var(--line)}
.divrow:nth-child(even) .div-media{order:2}
.div-media{position:relative;display:block;overflow:hidden;aspect-ratio:7/5;border-radius:14px;
  background:#dcdad2;border:1px solid var(--line);box-shadow:var(--shadow)}
.div-media img{width:100%;height:100%;object-fit:cover}
.div-media .mono{position:absolute;left:14px;top:12px;color:#fff;mix-blend-mode:difference;z-index:2}
.div-copy>.mono{color:var(--acc-d)}
.div-copy h3{font-family:var(--jp);font-weight:700;font-size:clamp(21px,2.4vw,31px);line-height:1.36;letter-spacing:-.01em;margin-top:9px;color:var(--ink)}
.div-copy>p{margin-top:14px;max-width:46ch;color:var(--ink2);font-size:14.5px;line-height:1.95}
.div-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:20px}
.div-tags li{font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink2);
  padding:6px 12px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.5)}
.div-link{display:inline-flex;align-items:center;gap:9px;margin-top:22px;font-family:var(--disp);font-weight:500;font-size:13.5px;color:var(--ink)}
.div-link .ar{color:var(--acc-d);transition:transform .35s var(--ease)}
.div-link:hover .ar{transform:translateX(4px)}

.spec{position:relative;background:var(--bg);border-top:1px solid var(--line)}
.spec .wrap{padding-block:clamp(70px,9vw,130px)}
.spec-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(28px,4.4vw,80px);align-items:start}
.spec-h{font-size:clamp(25px,3.6vw,46px)}
.spec-list{display:grid;gap:12px}
.spec-list div{padding:24px;border:1px solid var(--line);border-radius:14px;background:var(--paper);box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease),box-shadow .35s}
.spec-list div:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.spec-list dt{display:flex;align-items:baseline;gap:12px;font-family:var(--jp);font-weight:700;font-size:17px;color:var(--ink)}
.spec-list dt .mono{font-size:10.5px;color:var(--acc-d);border:1px solid var(--line2);width:22px;height:22px;display:inline-grid;place-items:center;border-radius:50%}
.spec-list dd{margin-top:10px;color:var(--ink2);font-size:14px;line-height:1.9}

.profile{position:relative;background:var(--s1);border-top:1px solid var(--line)}
.profile .wrap{padding-block:clamp(70px,9vw,130px)}
.profile-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(28px,4.4vw,80px);align-items:start}
.profile-h{font-size:clamp(24px,3.2vw,42px)}
.profile-list{border-top:1px solid var(--line)}
.profile-list div{display:grid;grid-template-columns:148px 1fr;gap:22px;padding:16px 0;border-bottom:1px solid var(--line)}
.profile-list dt{font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink3);padding-top:3px}
.profile-list dd{color:var(--ink);font-size:14.5px;line-height:1.8}

.contact{position:relative;background:var(--dark);color:#f0f3ef;border-top:1px solid var(--line);overflow:hidden}
.contact::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(56% 70% at 82% 14%,rgba(31,157,99,.3),transparent 60%)}
.contact .wrap{position:relative;z-index:1;padding-block:clamp(84px,11vw,154px)}
.contact .sec-index{color:rgba(240,243,239,.5)}
.contact-h{color:#f3f6f2;font-size:clamp(27px,4.4vw,60px);letter-spacing:-.022em;max-width:17ch}
.contact-h em{color:var(--acc-l)}
.contact-lead{margin-top:clamp(20px,2.6vw,32px);max-width:54ch;color:rgba(240,243,239,.72);font-size:15px;line-height:1.95}
.contact-tel{display:inline-flex;align-items:baseline;gap:14px;margin-top:clamp(30px,3.6vw,46px)}
.contact-tel .mono{font-size:12px;color:var(--acc-l)}
.contact-tel b{font-family:var(--disp);font-weight:600;font-size:clamp(32px,5.4vw,64px);letter-spacing:-.01em;color:#f3f6f2;transition:color .3s}
.contact-tel:hover b{color:var(--acc-l)}
.contact-sub{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:22px;color:rgba(240,243,239,.5);font-size:13px}
.contact-sub a{color:rgba(240,243,239,.8);border-bottom:1px solid rgba(240,243,239,.2);padding-bottom:2px}
.contact-sub a:hover{color:#fff;border-color:#fff}

.foot{background:var(--dark);color:rgba(240,243,239,.6)}
.foot .wrap{padding:clamp(30px,3.4vw,48px) var(--gut) 34px}
.foot-top{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;padding-bottom:24px}
.foot-brand{font-family:var(--jp);font-weight:700;font-size:16px;color:#f0f3ef}
.foot-nav{display:flex;gap:20px}
.foot-nav a{font-family:var(--disp);font-size:12.5px;color:rgba(240,243,239,.7)}
.foot-nav a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:20px;border-top:1px solid rgba(240,243,239,.14)}

@media (max-width:920px){
  .cursor{display:none}
  .head-nav,.head-tel{display:none}
  .head-burger{display:flex}
  .head-nav.is-mobile{display:flex;position:fixed;inset:74px 0 auto;flex-direction:column;gap:0;
    padding:8px var(--gut) 26px;background:rgba(244,243,238,.96);backdrop-filter:blur(18px);border-bottom:1px solid var(--line);
    transform:translateY(-118%);transition:transform .45s var(--ease)}
  html.nav-open .head-nav.is-mobile{transform:none}
  .head-nav.is-mobile a{font-family:var(--jp);font-size:16px;color:var(--ink);padding:15px 0;border-bottom:1px solid var(--line)}
  .hero{height:100svh;min-height:520px}
  .hero-scrollhint{display:none}
  .philo-grid,.spec-grid,.profile-grid{grid-template-columns:1fr;gap:22px}
  .divrow{grid-template-columns:1fr;gap:20px}
  .divrow:nth-child(even) .div-media{order:0}
}
@media (max-width:560px){
  .hero-h{font-size:clamp(30px,8.4vw,42px)}
  .hero-cta{width:56px;height:56px;font-size:18px}
  .contact-tel{flex-direction:column;gap:6px}
  .profile-list div{grid-template-columns:1fr;gap:3px}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .loader,.cursor{display:none}
  .hero-bg{inset:0}
  .div-media img{height:100%}
  [data-split] .li{transform:none!important}
}
