/* =========================================================
   CLEANEST — editorial house-cleaning site
   Reference DNA: homecourt.co (warm greige + sage, editorial serif, sharp radius)
   ========================================================= */

:root{
  /* surfaces */
  --bg:#f6f3ec;
  --paper:#fcfbf7;
  --cream:#f1ead9;
  --greige:#bdb7a7;
  --line:#e4ddcf;
  --line-soft:#ece6da;

  /* ink */
  --ink:#23261f;
  --ink-soft:#54574d;
  --ink-mute:#8d8b7e;

  /* accent = 清潔の一滴（dusty blue） */
  --sage:#5b7fa6;
  --sage-deep:#3f6b97;

  /* dark sections = slate navy */
  --forest:#21364f;
  --forest-deep:#16243a;
  --forest-paper:#eef1f5;

  /* cta */
  --cta:#345f8c;
  --cta-hover:#284a6e;

  --maxw:1200px;
  --maxw-narrow:880px;
  --r:6px;
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:"Noto Sans JP",system-ui,sans-serif;
  font-weight:400;
  line-height:1.85;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul,ol{margin:0;padding:0;list-style:none;}
h1,h2,h3,h4{margin:0;font-weight:700;line-height:1.32;letter-spacing:.01em;}
p{margin:0;text-wrap:pretty;}
.ico{width:1em;height:1em;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;}

/* ---------- layout ---------- */
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 40px;}
.container-narrow{max-width:var(--maxw-narrow);}
.section{padding:130px 0;position:relative;z-index:2;}

.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:"Fraunces",serif;font-style:italic;font-weight:500;
  font-size:15px;letter-spacing:.04em;color:var(--sage-deep);
  margin-bottom:22px;
}
.eyebrow i{
  font-style:normal;font-family:"Inter",sans-serif;font-weight:600;
  font-size:12px;letter-spacing:.16em;color:var(--ink-mute);
  padding-right:12px;border-right:1px solid var(--line);
}
.eyebrow-light{color:#b3cbe2;}
.eyebrow-light i{color:rgba(255,255,255,.55);border-color:rgba(255,255,255,.25);}

.section-head{max-width:680px;margin-bottom:68px;}
.section-title{
  font-family:"Shippori Mincho B1",serif;font-weight:700;
  font-size:clamp(30px,4.6vw,52px);line-height:1.25;letter-spacing:.015em;
  margin-bottom:24px;
}
.section-lead{color:var(--ink-soft);font-size:16px;font-weight:300;line-height:2.05;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:"Noto Sans JP",sans-serif;font-weight:500;font-size:15px;
  letter-spacing:.02em;padding:15px 30px;border-radius:var(--r);
  border:1px solid transparent;cursor:pointer;
  transition:background .25s var(--ease),color .25s var(--ease),
             border-color .25s var(--ease),transform .35s var(--ease-spring),
             box-shadow .35s var(--ease);
  will-change:transform;
}
.btn-lg{padding:18px 40px;font-size:16px;}
.btn-primary{background:var(--cta);color:#fff;box-shadow:0 8px 22px rgba(52,95,140,.20);}
.btn-primary:hover{background:var(--cta-hover);transform:translateY(-3px);box-shadow:0 14px 30px rgba(52,95,140,.28);}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink);}
.btn-ghost:hover{background:var(--ink);color:var(--bg);transform:translateY(-3px);}
.btn-light{background:#fff;color:var(--forest-deep);}
.btn-light:hover{background:#f0ede4;transform:translateY(-3px);box-shadow:0 14px 30px rgba(0,0,0,.18);}

/* ---------- header ---------- */
.header{
  position:fixed;top:0;left:0;width:100%;z-index:800;
  padding:24px 0;
  transition:padding .4s var(--ease),background .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);
  border-bottom:1px solid transparent;
  opacity:0;transform:translateY(-14px);
}
body.is-loaded .header{opacity:1;transform:translateY(0);transition:opacity .9s ease .25s,transform .9s var(--ease-spring) .25s,padding .4s var(--ease),background .4s var(--ease),box-shadow .4s var(--ease);}
.header.scrolled{
  padding:14px 0;background:rgba(246,243,236,.86);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-color:var(--line);box-shadow:0 6px 24px rgba(35,38,31,.05);
}
.header-inner{
  max-width:var(--maxw);margin:0 auto;padding:0 40px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.logo{display:inline-flex;align-items:baseline;gap:9px;}
.logo-kabu{font-size:11px;font-weight:500;letter-spacing:.14em;color:var(--ink-soft);transform:translateY(-2px);}
.logo-name{font-family:"Fraunces",serif;font-weight:600;font-size:23px;letter-spacing:.12em;color:var(--ink);}
.nav{display:flex;gap:30px;}
.nav a{
  font-size:14px;font-weight:500;color:var(--ink-soft);position:relative;padding:4px 0;
  transition:color .25s var(--ease);
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--sage-deep);
  transition:width .3s var(--ease);
}
.nav a:hover{color:var(--ink);}
.nav a:hover::after{width:100%;}
.header-cta{display:flex;align-items:center;gap:18px;}
.header-tel{display:inline-flex;align-items:center;gap:7px;font-family:"Inter",sans-serif;font-weight:600;font-size:16px;color:var(--ink);}
.header-tel .ico{width:17px;height:17px;color:var(--sage-deep);}
.header-tel:hover{color:var(--sage-deep);}
.header-btn{padding:11px 22px;font-size:14px;}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;}
.burger span{display:block;width:24px;height:2px;background:var(--ink);transition:.3s var(--ease);}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-start;overflow:hidden;}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:linear-gradient(135deg,#e9e2d2 0%,#dde2ea 48%,#ccd6e2 100%);
  background-image:linear-gradient(115deg,rgba(33,54,79,.16),rgba(33,54,79,0) 55%),url("../images/hero.jpg");
  background-size:cover;background-position:center 38%;
  transform:scale(1.06);
  transition:transform 8s ease;
}
body.is-loaded .hero-bg{transform:scale(1);}
.hero-veil{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(246,243,236,.92) 0%,rgba(246,243,236,.72) 36%,rgba(246,243,236,.28) 64%,rgba(246,243,236,.05) 100%);
}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:158px 40px 80px;width:100%;}
.hero-eyebrow{
  display:block;font-family:"Fraunces",serif;font-style:italic;font-weight:400;
  font-size:clamp(17px,2vw,22px);color:var(--sage-deep);margin-bottom:24px;letter-spacing:.02em;
}
.hero-title{
  font-family:"Shippori Mincho B1",serif;font-weight:700;
  font-size:clamp(46px,8.2vw,108px);line-height:1.1;letter-spacing:.02em;color:var(--ink);
  margin-bottom:30px;
}
.hero-sub{
  font-size:clamp(15px,1.5vw,18px);font-weight:300;line-height:2.15;color:var(--ink-soft);
  margin-bottom:40px;max-width:34em;
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:44px;}
.hero-chips{display:flex;flex-wrap:wrap;gap:10px;}
.hero-chips li{
  font-size:13px;font-weight:500;color:var(--ink-soft);
  padding:8px 16px;border:1px solid var(--line);border-radius:100px;
  background:rgba(252,251,247,.6);backdrop-filter:blur(4px);
}
.hero-scroll{position:absolute;left:50%;bottom:34px;z-index:2;transform:translateX(-50%);}
.hero-scroll span{display:block;width:1px;height:54px;background:linear-gradient(var(--ink),transparent);animation:scrollPulse 2.2s ease infinite;transform-origin:top;}
@keyframes scrollPulse{0%,100%{transform:scaleY(.4);opacity:.4;}50%{transform:scaleY(1);opacity:1;}}

/* ---------- trust bar ---------- */
.trust{position:relative;z-index:2;background:var(--forest);color:#f3efe3;}
.trust-grid{
  max-width:var(--maxw);margin:0 auto;padding:0 40px;
  display:grid;grid-template-columns:repeat(4,1fr);
}
.trust-item{
  padding:54px 28px;text-align:center;border-right:1px solid rgba(255,255,255,.12);
  display:flex;flex-direction:column;align-items:center;
}
.trust-item:last-child{border-right:0;}
.trust-num{font-family:"Fraunces",serif;font-weight:500;font-size:54px;line-height:1;color:#fff;}
.trust-num-txt{font-family:"Shippori Mincho B1",serif;font-weight:700;font-size:46px;line-height:1.17;}
.trust-unit{font-family:"Fraunces",serif;font-size:20px;color:#b3cbe2;margin-top:4px;}
.trust-label{font-size:13px;font-weight:300;line-height:1.7;color:rgba(243,239,227,.78);margin-top:14px;}

/* ---------- services ---------- */
.services{background:var(--bg);}
.svc-hero{
  width:100%;aspect-ratio:16/6.2;border-radius:var(--r);overflow:hidden;margin-bottom:56px;
  background:#d7dde2 url("../images/service-intro.jpg") center/cover no-repeat;
}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;}
.svc-card{
  background:var(--paper);padding:42px 34px;position:relative;
  transition:background .4s var(--ease),transform .4s var(--ease);
}
.svc-card:hover{background:#fff;}
.svc-ico{display:flex;width:46px;height:46px;margin-bottom:22px;color:var(--sage-deep);}
.svc-ico svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round;}
.svc-card h3{font-size:18px;font-weight:700;margin-bottom:12px;letter-spacing:.02em;}
.svc-card p{font-size:14px;font-weight:300;color:var(--ink-soft);line-height:1.95;}
.svc-card-feature{
  grid-column:span 2;background:var(--cream);
  display:flex;align-items:center;gap:34px;
}
.svc-card-feature:hover{background:#f4eede;}
.svc-card-feature .svc-ico{margin-bottom:0;flex:0 0 auto;}
.feat-text{flex:1;min-width:0;}
.feat-text h3{margin-bottom:10px;}
.feat-text p{max-width:42em;}
.feat-side{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;gap:6px;}
.feat-price{font-size:14px;font-weight:500;color:var(--ink);white-space:nowrap;}
.feat-price em{font-family:"Fraunces",serif;font-style:normal;font-weight:600;font-size:30px;letter-spacing:.01em;}
.feat-price-note{font-size:11px;font-weight:400;letter-spacing:.04em;color:var(--ink-mute);}
.feat-cta{
  margin-top:6px;display:inline-flex;align-items:center;gap:9px;
  font-weight:600;font-size:14px;letter-spacing:.02em;color:var(--cta);white-space:nowrap;
}
.feat-cta span{transition:transform .3s var(--ease);}
.svc-card-feature:hover .feat-cta span{transform:translateX(5px);}

/* pricing set row */
.price-row-set{background:var(--cream);}
.price-row-set .price-name{font-weight:700;}
.price-sub{display:block;font-size:12px;font-weight:300;color:var(--ink-soft);margin-top:3px;letter-spacing:.02em;}
.svc-tag{
  position:absolute;top:24px;right:24px;
  font-family:"Inter",sans-serif;font-size:10px;font-weight:600;letter-spacing:.12em;
  color:#fff;background:var(--sage-deep);padding:5px 11px;border-radius:100px;
}

/* ---------- pricing ---------- */
.pricing{background:var(--paper);}
.price-table{border-top:1px solid var(--ink);}
.price-row{
  display:grid;grid-template-columns:1.6fr 1fr .9fr;align-items:center;gap:24px;
  padding:22px 14px;border-bottom:1px solid var(--line);
  transition:background .3s var(--ease);
}
.price-row:not(.price-row-head):hover{background:var(--cream);}
.price-row-head{
  font-family:"Inter",sans-serif;font-size:12px;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-mute);padding:14px;
}
.price-name{font-size:16px;font-weight:500;}
.price-time{font-size:14px;font-weight:300;color:var(--ink-soft);}
.price-amount{text-align:right;font-size:15px;font-weight:500;color:var(--ink);}
.price-amount em{font-family:"Fraunces",serif;font-style:normal;font-weight:600;font-size:24px;letter-spacing:.01em;}
.price-amount-quote{font-family:"Shippori Mincho B1",serif;color:var(--sage-deep);}
.price-note{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:40px;}
.price-note-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:34px 32px;}
.price-note-card h4{font-family:"Shippori Mincho B1",serif;font-size:19px;font-weight:700;margin-bottom:12px;}
.price-note-card p{font-size:14px;font-weight:300;color:var(--ink-soft);line-height:1.95;}
.price-note-cta{background:var(--forest);color:#f3efe3;border-color:var(--forest);}
.price-note-cta h4{color:#fff;}
.price-note-cta p{color:rgba(243,239,227,.8);margin-bottom:20px;}

/* ---------- flow ---------- */
.flow{background:var(--bg);}
.flow-list{display:grid;gap:0;border-left:1px solid var(--line);margin-left:8px;}
.flow-step{
  display:grid;grid-template-columns:auto 1fr;gap:34px;align-items:flex-start;
  padding:34px 0 34px 40px;position:relative;
}
.flow-step::before{
  content:"";position:absolute;left:-5px;top:44px;width:9px;height:9px;border-radius:50%;
  background:var(--bg);border:2px solid var(--sage-deep);
}
.flow-no{font-family:"Fraunces",serif;font-weight:400;font-size:40px;color:var(--greige);line-height:1;min-width:64px;}
.flow-body h3{font-size:21px;font-weight:700;font-family:"Shippori Mincho B1",serif;margin-bottom:8px;}
.flow-body p{font-size:15px;font-weight:300;color:var(--ink-soft);}

/* ---------- reasons ---------- */
.reasons{background:var(--cream);}
.reason-list{display:grid;gap:0;}
.reason{
  display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:flex-start;
  padding:40px 0;border-top:1px solid var(--line);
}
.reason:last-child{border-bottom:1px solid var(--line);}
.reason-no{font-family:"Fraunces",serif;font-weight:300;font-size:clamp(40px,5vw,68px);line-height:1;color:var(--sage);min-width:1.6em;}
.reason-body h3{font-family:"Shippori Mincho B1",serif;font-size:clamp(21px,2.6vw,28px);font-weight:700;margin-bottom:14px;}
.reason-body p{font-size:15px;font-weight:300;color:var(--ink-soft);line-height:2.05;max-width:46em;}

/* quality strip */
.quality{
  max-width:var(--maxw);margin:90px auto 0;padding:0 40px;
  display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;
  border-radius:var(--r);overflow:hidden;
}
.quality-media{
  min-height:440px;
  background:#8ea6c2 url("../images/quality.jpg") center/cover no-repeat;
}
.quality-text{background:var(--forest);color:#f3efe3;padding:64px 56px;}
.quality-text h3{font-family:"Shippori Mincho B1",serif;font-size:clamp(24px,3vw,32px);font-weight:700;color:#fff;margin-bottom:30px;line-height:1.4;}
.quality-points{display:grid;gap:18px;}
.quality-points li{
  position:relative;padding-left:30px;font-size:15px;font-weight:300;line-height:1.85;color:rgba(243,239,227,.86);
}
.quality-points li::before{
  content:"";position:absolute;left:0;top:11px;width:14px;height:8px;
  border-left:1.5px solid var(--sage);border-bottom:1.5px solid var(--sage);transform:rotate(-45deg);
}

/* ---------- voices ---------- */
.voices{position:relative;background:var(--bg);overflow:hidden;}
.voices::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:#dcd6c8 url("../images/voices.jpg") center/cover no-repeat;opacity:.5;
}
.voices::after{
  content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,rgba(246,243,236,.62),rgba(246,243,236,.86));
}
.voices .container{position:relative;z-index:2;}
.voice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.voice-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:42px 40px;position:relative;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.voice-card::before{
  content:"\201C";position:absolute;top:18px;left:30px;
  font-family:"Fraunces",serif;font-size:64px;color:var(--greige);opacity:.5;line-height:1;
}
.voice-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(35,38,31,.07);}
.voice-card blockquote{margin:24px 0 22px;font-size:16px;font-weight:300;line-height:2;color:var(--ink);}
.voice-card figcaption{font-family:"Inter",sans-serif;font-size:13px;font-weight:500;letter-spacing:.04em;color:var(--sage-deep);}

/* ---------- area ---------- */
.area{background:var(--cream);}
.area-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.area-list{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.area-list li{
  font-family:"Shippori Mincho B1",serif;font-size:clamp(24px,3.2vw,36px);font-weight:700;
  text-align:center;padding:38px 0;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  transition:background .3s var(--ease),color .3s var(--ease),transform .3s var(--ease);
}
.area-list li:hover{background:var(--forest);color:#fff;transform:translateY(-3px);}
.area .btn{margin-top:34px;}

/* ---------- faq ---------- */
.faq{background:var(--bg);}
.faq-list{border-top:1px solid var(--line);}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{
  width:100%;text-align:left;background:none;border:0;cursor:pointer;
  font-family:"Noto Sans JP",sans-serif;font-size:17px;font-weight:500;color:var(--ink);
  padding:28px 50px 28px 0;position:relative;line-height:1.6;
}
.faq-q::before{content:"Q";font-family:"Fraunces",serif;font-style:italic;color:var(--sage-deep);margin-right:16px;font-size:18px;}
.faq-mark{position:absolute;right:6px;top:50%;width:14px;height:14px;transform:translateY(-50%);}
.faq-mark::before,.faq-mark::after{content:"";position:absolute;background:var(--sage-deep);transition:transform .35s var(--ease);}
.faq-mark::before{left:0;top:6px;width:14px;height:1.5px;}
.faq-mark::after{left:6px;top:0;width:1.5px;height:14px;}
.faq-item.open .faq-mark::after{transform:scaleY(0);}
.faq-a{overflow:hidden;max-height:0;transition:max-height .4s var(--ease);}
.faq-a p{padding:0 50px 30px 34px;font-size:15px;font-weight:300;color:var(--ink-soft);line-height:2;}

/* ---------- guide ---------- */
.guide{background:var(--paper);}
.guide-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.guide-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:40px 38px;}
.guide-card h3{font-family:"Shippori Mincho B1",serif;font-size:20px;font-weight:700;margin-bottom:20px;}
.guide-card ul{display:grid;gap:11px;}
.guide-card li{position:relative;padding-left:22px;font-size:14.5px;font-weight:300;color:var(--ink-soft);line-height:1.8;}
.guide-card li::before{content:"";position:absolute;left:0;top:11px;width:6px;height:6px;border-radius:50%;background:var(--sage);}
.guide-note{font-size:13px;font-weight:300;color:var(--ink-mute);margin-top:16px;line-height:1.8;}
.guide-policy li{display:flex;justify-content:space-between;padding-left:0;border-bottom:1px dashed var(--line);padding-bottom:11px;}
.guide-policy li::before{display:none;}
.guide-policy span{color:var(--ink-soft);}
.guide-policy b{font-weight:600;color:var(--ink);}

/* ---------- corporate ---------- */
.corporate{background:var(--bg);}
.corporate-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.corporate-list{display:grid;gap:0;}
.corporate-list li{
  font-size:16px;font-weight:400;padding:22px 0 22px 32px;border-top:1px solid var(--line);position:relative;
}
.corporate-list li:last-child{border-bottom:1px solid var(--line);}
.corporate-list li::before{content:"";position:absolute;left:0;top:31px;width:14px;height:1px;background:var(--sage-deep);}

/* ---------- final cta ---------- */
.cta{position:relative;padding:140px 0;color:#f3efe3;overflow:hidden;z-index:2;}
.cta-bg{position:absolute;inset:0;z-index:0;background:linear-gradient(150deg,var(--forest) 0%,var(--forest-deep) 100%);}
.cta-bg::after{
  content:"";position:absolute;inset:0;
  background-image:url("../images/cta.jpg");background-size:cover;background-position:center;
  opacity:.22;mix-blend-mode:luminosity;
}
.cta-inner{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 40px;text-align:center;}
.cta-title{font-family:"Shippori Mincho B1",serif;font-size:clamp(32px,5.5vw,64px);font-weight:700;color:#fff;line-height:1.25;margin:18px 0 26px;}
.cta-sub{font-size:16px;font-weight:300;line-height:2.05;color:rgba(243,239,227,.85);margin-bottom:48px;}
.cta-actions{display:flex;gap:24px;justify-content:center;align-items:stretch;flex-wrap:wrap;}
.cta-tel{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.22);border-radius:var(--r);
  padding:20px 44px;transition:background .3s var(--ease),transform .35s var(--ease-spring);
}
.cta-tel:hover{background:rgba(255,255,255,.1);transform:translateY(-3px);}
.cta-tel-label{font-size:12px;font-weight:300;letter-spacing:.06em;color:rgba(243,239,227,.7);}
.cta-tel-num{font-family:"Fraunces",serif;font-weight:600;font-size:36px;letter-spacing:.04em;color:#fff;line-height:1.1;}
.cta-tel-note{font-size:11px;letter-spacing:.1em;color:#b3cbe2;}
.cta-form{align-self:center;}

/* ---------- company ---------- */
.company{background:var(--paper);}
.company-table{border-top:1px solid var(--ink);}
.company-table>div{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:20px 8px;border-bottom:1px solid var(--line);}
.company-table dt{font-size:14px;font-weight:500;color:var(--ink-soft);}
.company-table dd{font-size:15px;font-weight:400;margin:0;}
.company-table a{color:var(--sage-deep);border-bottom:1px solid transparent;transition:border-color .25s;}
.company-table a:hover{border-color:var(--sage-deep);}

/* ---------- footer ---------- */
.footer{background:var(--forest-deep);color:rgba(243,239,227,.8);padding:80px 0 0;}
.footer-inner{display:grid;grid-template-columns:1.4fr 1.4fr 1fr;gap:40px;padding-bottom:54px;}
.footer-logo{display:inline-flex;align-items:baseline;gap:9px;}
.footer-logo .logo-kabu{color:rgba(243,239,227,.6);}
.footer-logo .logo-name{font-family:"Fraunces",serif;font-weight:600;font-size:24px;letter-spacing:.12em;color:#fff;}
.footer-tagline{font-family:"Shippori Mincho B1",serif;font-size:15px;color:rgba(243,239,227,.7);margin-top:16px;}
.footer-nav{display:flex;flex-wrap:wrap;gap:14px 28px;align-content:flex-start;}
.footer-nav a{font-size:14px;font-weight:300;color:rgba(243,239,227,.75);transition:color .25s;}
.footer-nav a:hover{color:#fff;}
.footer-contact{text-align:right;}
.footer-tel{font-family:"Fraunces",serif;font-weight:600;font-size:26px;color:#fff;letter-spacing:.03em;}
.footer-contact-note{display:block;font-size:12px;font-weight:300;color:#b3cbe2;margin-top:6px;}
.footer-base{
  border-top:1px solid rgba(255,255,255,.1);padding:22px 40px;max-width:var(--maxw);margin:0 auto;width:100%;
  display:flex;justify-content:space-between;font-size:12px;font-weight:300;letter-spacing:.04em;color:rgba(243,239,227,.5);
}

/* ---------- mobile sticky cta ---------- */
.mobile-cta{
  position:fixed;left:0;bottom:0;width:100%;z-index:850;
  display:none;grid-template-columns:1fr 1.2fr;gap:0;
  background:rgba(252,251,247,.94);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);box-shadow:0 -6px 24px rgba(35,38,31,.08);
  transform:translateY(110%);transition:transform .5s var(--ease);
}
.mobile-cta.show{transform:translateY(0);}
.mobile-cta a{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 8px;font-size:15px;font-weight:600;}
.mobile-cta-tel{color:var(--ink);}
.mobile-cta-tel .ico{width:18px;height:18px;color:var(--sage-deep);}
.mobile-cta-form{background:var(--cta);color:#fff;margin:8px;border-radius:var(--r);}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform 1s var(--ease);}
.reveal.in{opacity:1;transform:translateY(0);}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .section{padding:100px 0;}
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .nav{gap:22px;}
  .header-tel-num{display:none;}
}

@media (max-width:880px){
  .container,.header-inner{padding:0 24px;}
  .section{padding:84px 0;}
  .svc-hero{aspect-ratio:16/9;margin-bottom:32px;}
  .nav{
    position:fixed;inset:0 0 0 auto;width:78%;max-width:340px;height:100vh;
    background:var(--paper);flex-direction:column;justify-content:center;gap:8px;padding:40px;
    transform:translateX(100%);transition:transform .5s var(--ease);box-shadow:-20px 0 50px rgba(0,0,0,.1);
  }
  .nav.open{transform:translateX(0);}
  .nav a{font-size:19px;font-family:"Shippori Mincho B1",serif;padding:12px 0;}
  .burger{display:flex;z-index:810;}
  .header-cta{display:none;}
  .section-head{margin-bottom:48px;}

  .hero{align-items:flex-start;}
  .hero-inner{padding:118px 24px 56px;}
  .hero-sub{margin-bottom:34px;}

  .trust-grid{grid-template-columns:repeat(2,1fr);}
  .trust-item{padding:42px 14px;border-bottom:1px solid rgba(255,255,255,.12);}
  .trust-num{font-size:44px;}
  .trust-num-txt{font-size:38px;}
  .trust-unit{font-size:17px;}
  .trust-label{font-size:12px;letter-spacing:0;margin-top:12px;}
  .trust-item:nth-child(2){border-right:0;}
  .trust-item:nth-child(3),.trust-item:nth-child(4){border-bottom:0;}

  .price-row{grid-template-columns:1.4fr .9fr;gap:10px 16px;padding:20px 10px;}
  .price-time{grid-column:1;grid-row:2;}
  .price-amount{grid-column:2;grid-row:1 / span 2;}
  .price-row-head .price-time{display:none;}
  .price-note{grid-template-columns:1fr;}

  .quality{grid-template-columns:1fr;max-width:none;margin:60px 0 0;padding:0;border-radius:0;}
  .quality-media{min-height:280px;}
  .quality-text{padding:48px 24px;}

  .voice-grid{grid-template-columns:1fr;}
  .area-inner,.corporate-inner{grid-template-columns:1fr;gap:40px;}
  .guide-grid{grid-template-columns:1fr;}

  .cta{padding:96px 0;}
  .cta-actions{flex-direction:column;gap:16px;}
  .cta-tel{padding:18px 28px;}

  .company-table>div{grid-template-columns:1fr;gap:4px;padding:18px 6px;}
  .company-table dt{font-size:12px;color:var(--ink-mute);}

  .footer-inner{grid-template-columns:1fr;gap:30px;}
  .footer-contact{text-align:left;}
  .footer-base{flex-direction:column;gap:8px;padding:22px 24px;}

  .mobile-cta{display:grid;}
}

@media (max-width:560px){
  .svc-grid{grid-template-columns:1fr;}
  .svc-card-feature{grid-column:auto;flex-direction:column;align-items:flex-start;gap:18px;}
  .svc-card-feature .feat-side{align-items:flex-start;}
  .feat-text p{max-width:none;}
  .hero-bg{
    background:#dde2ea url("../images/hero-mobile.jpg") center / cover no-repeat;
  }
  .hero-veil{background:linear-gradient(180deg,rgba(246,243,236,.96) 0%,rgba(246,243,236,.93) 40%,rgba(246,243,236,.8) 62%,rgba(246,243,236,.42) 80%,rgba(246,243,236,.08) 100%);}
  .hero-title{font-size:clamp(40px,11vw,72px);}
  .hero-sub{font-size:14px;line-height:2;}
  .hero-actions{flex-direction:column;}
  .hero-actions .btn{width:100%;}
  .area-list{grid-template-columns:1fr 1fr;}
  .reason{grid-template-columns:1fr;gap:8px;}
  .flow-step{gap:18px;padding-left:30px;}
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.05ms!important;}
  .reveal{opacity:1;transform:none;}
  .hero-bg{transform:none;}
}
