/* =========================================================
   水道のSafety — 共通スタイル
   タイポ: Zen Kaku Gothic New / Noto Sans JP / Outfit
   配色 : 水を思わせるブルー（oklchベース）
   ========================================================= */

:root{
  /* --- color tokens --- */
  --ink:        oklch(0.28 0.035 255);
  --ink-soft:   oklch(0.44 0.025 255);
  --muted:      oklch(0.56 0.018 255);
  --line:       oklch(0.91 0.012 245);
  --line-soft:  oklch(0.94 0.010 245);

  --bg:         oklch(0.995 0.003 240);
  --bg-soft:    oklch(0.975 0.013 238);
  --bg-blue:    oklch(0.955 0.022 238);

  --primary:      oklch(0.55 0.15 250);
  --primary-dark: oklch(0.45 0.14 254);
  --primary-deep: oklch(0.32 0.10 258);
  --primary-tint: oklch(0.93 0.035 240);
  --accent:       oklch(0.74 0.12 212);
  --accent-deep:  oklch(0.62 0.13 218);

  --emph:       oklch(0.68 0.17 45);   /* 緊急・強調のオレンジ */
  --line-green: #06C755;
  --line-green-d:#05b14d;

  --white: #fff;

  /* --- type --- */
  --f-head: "Zen Kaku Gothic New", "Noto Sans JP", sans-serif;
  --f-body: "Noto Sans JP", sans-serif;
  --f-num:  "Outfit", "Noto Sans JP", sans-serif;

  /* --- shape --- */
  --r-sm: 8px;
  --r:    14px;
  --r-lg: 22px;
  --r-pill: 999px;

  --shadow-sm: 0 2px 8px rgba(20,50,90,.06);
  --shadow:    0 10px 30px -12px rgba(20,55,100,.20);
  --shadow-lg: 0 28px 60px -24px rgba(15,45,95,.32);

  --container: 1180px;
  --gutter: clamp(18px, 5vw, 56px);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }

body{
  margin:0;
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--bg);
  font-size:16px;
  line-height:1.85;
  font-feature-settings:"palt" 1;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

h1,h2,h3,h4{ font-family:var(--f-head); font-weight:700; line-height:1.35; margin:0; letter-spacing:.02em; }

.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--gutter);
}

/* =========================================================
   ヘッダー
   ========================================================= */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .3s, box-shadow .3s, background .3s;
}
.site-header.scrolled{
  border-bottom-color:var(--line);
  box-shadow:0 6px 24px -18px rgba(15,45,95,.4);
}
.header-inner{
  display:flex; align-items:center; gap:24px;
  height:74px;
}
.brand{ display:flex; align-items:center; gap:11px; flex-shrink:0; }
.brand .mark{
  width:42px; height:42px; flex-shrink:0;
  display:grid; place-items:center;
  background:linear-gradient(155deg, var(--primary), var(--primary-dark));
  border-radius:13px;
  box-shadow:0 6px 16px -6px var(--primary);
}
.brand .mark svg{ width:23px; height:23px; }
.brand .name{ line-height:1.15; }
.brand .name b{
  font-family:var(--f-head); font-weight:900; font-size:20px;
  letter-spacing:.04em; color:var(--ink); display:block;
}
.brand .name span{
  font-family:var(--f-num); font-size:10.5px; letter-spacing:.34em;
  color:var(--primary); font-weight:600; text-transform:uppercase;
}

.nav{ display:flex; align-items:center; gap:2px; margin-left:auto; flex-wrap:nowrap; }
.nav a{
  padding:10px 11px; font-size:14px; font-weight:700; white-space:nowrap;
  color:var(--ink-soft); border-radius:var(--r-pill);
  transition:color .2s, background .2s;
  font-family:var(--f-head); letter-spacing:.02em;
}
.nav a:hover{ color:var(--primary-dark); background:var(--primary-tint); }
.nav a.active{ color:var(--primary-dark); }

.header-cta{ display:flex; align-items:center; gap:10px; flex-shrink:0; }
.tel-mini{ text-align:right; line-height:1.1; }
.tel-mini span{ font-size:10px; color:var(--muted); letter-spacing:.18em; font-weight:600; }
.tel-mini b{
  font-family:var(--f-num); font-weight:800; font-size:21px; color:var(--primary-dark);
  display:flex; align-items:center; gap:5px; letter-spacing:.01em;
}
.tel-mini b svg{ width:15px; height:15px; }

.menu-toggle{
  display:none; width:46px; height:46px; border:1px solid var(--line);
  background:var(--white); border-radius:12px; padding:0;
  flex-direction:column; gap:5px; align-items:center; justify-content:center;
}
.menu-toggle span{ width:20px; height:2px; background:var(--ink); border-radius:2px; transition:.25s; }
.menu-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.menu-toggle.open span:nth-child(2){ opacity:0; }
.menu-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* =========================================================
   ボタン
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:14px 26px; border-radius:var(--r-pill); border:none;
  font-family:var(--f-head); font-weight:700; font-size:15px; letter-spacing:.04em;
  transition:transform .15s, box-shadow .25s, background .25s, filter .2s;
  white-space:nowrap; line-height:1;
}
.btn svg{ width:18px; height:18px; flex-shrink:0; }
.btn:hover{ transform:translateY(-2px); }
.btn:active{ transform:translateY(0); }

.btn-primary{ background:linear-gradient(150deg,var(--primary),var(--primary-dark)); color:#fff; box-shadow:0 12px 26px -12px var(--primary); }
.btn-primary:hover{ box-shadow:0 16px 32px -12px var(--primary); }
.btn-line{ background:var(--line-green); color:#fff; box-shadow:0 12px 26px -12px var(--line-green); }
.btn-line:hover{ background:var(--line-green-d); }
.btn-tel{ background:#fff; color:var(--primary-dark); border:1.5px solid var(--primary); }
.btn-tel:hover{ background:var(--primary-tint); }
.btn-ghost{ background:#fff; color:var(--ink); border:1.5px solid var(--line); }
.btn-ghost:hover{ border-color:var(--primary); color:var(--primary-dark); }
.btn-lg{ padding:18px 34px; font-size:16.5px; }
.btn-block{ width:100%; }

/* =========================================================
   汎用セクション
   ========================================================= */
.section{ padding:clamp(64px,9vw,118px) 0; position:relative; }
.section.soft{ background:var(--bg-soft); }
.section.blue{ background:var(--bg-blue); }

.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--f-num); font-weight:700; font-size:12.5px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--primary);
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--primary); border-radius:2px; }
.eyebrow.center::after{ content:""; width:26px; height:2px; background:var(--primary); border-radius:2px; }

.sec-head{ margin-bottom:clamp(36px,5vw,58px); }
.sec-head.center{ text-align:center; display:flex; flex-direction:column; align-items:center; }
.sec-title{
  font-size:clamp(26px,4vw,40px); margin-top:14px; color:var(--ink);
  line-height:1.4; letter-spacing:.02em;
  word-break:auto-phrase; line-break:strict; text-wrap:balance;
}
.sec-title .hl{ color:var(--primary-dark); }
.sec-lead{ margin-top:18px; color:var(--ink-soft); font-size:16px; max-width:60ch;
  word-break:auto-phrase; line-break:strict; text-wrap:pretty; }
.sec-head.center .sec-lead{ text-align:center; }

/* =========================================================
   波形ディバイダー
   ========================================================= */
.wave{ display:block; width:100%; height:auto; line-height:0; }
.wave svg{ display:block; width:100%; height:clamp(40px,6vw,90px); }

/* reveal — 初期非表示は JS 有効時（.js-anim）のみ。JS が動かなくても内容は見える */
.js-anim .reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1 !important; transform:none !important; }
.reveal.d1{ transition-delay:.08s; }
.reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; }
.reveal.d4{ transition-delay:.32s; }

/* =========================================================
   カード（サービス）
   ========================================================= */
.card-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.svc-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:28px 24px 26px; transition:transform .25s, box-shadow .25s, border-color .25s;
  position:relative; overflow:hidden;
}
.svc-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.svc-ico{
  width:56px; height:56px; border-radius:16px; display:grid; place-items:center;
  background:var(--primary-tint); color:var(--primary-dark); margin-bottom:18px;
  transition:background .25s, color .25s;
}
.svc-card:hover .svc-ico{ background:linear-gradient(150deg,var(--primary),var(--primary-dark)); color:#fff; }
.svc-ico svg{ width:28px; height:28px; }
.svc-card h3{ font-size:18px; letter-spacing:.03em; }
.svc-card p{ margin:9px 0 0; font-size:13.5px; color:var(--muted); line-height:1.8; }
.svc-card .price-hint{
  margin-top:16px; font-family:var(--f-num); font-weight:700; color:var(--primary-dark); font-size:13px;
}
.svc-card .price-hint b{ font-size:21px; }

/* =========================================================
   強み（選ばれる理由）
   ========================================================= */
.reason-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.reason{
  background:#fff; border-radius:var(--r-lg); padding:34px 30px;
  box-shadow:var(--shadow-sm); border:1px solid var(--line-soft);
}
.reason .num{
  font-family:var(--f-num); font-weight:800; font-size:13px; letter-spacing:.2em;
  color:var(--accent-deep);
}
.reason .r-ico{ display:grid; place-items:center; width:52px; height:52px; color:var(--primary); margin:14px 0 16px; }
.reason .r-ico svg{ width:100%; height:100%; }
.reason h3{ font-size:21px; }
.reason p{ margin:12px 0 0; color:var(--ink-soft); font-size:14.5px; }

/* =========================================================
   対応の流れ（ステップ）
   ========================================================= */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; counter-reset:step; }
.step{ position:relative; background:#fff; border-radius:var(--r); padding:30px 22px 26px; border:1px solid var(--line); }
.step::before{
  counter-increment:step; content:"0" counter(step);
  font-family:var(--f-num); font-weight:800; font-size:34px;
  color:var(--primary-tint); position:absolute; top:14px; right:18px;
}
.step .s-ico{ display:grid; place-items:center; width:44px; height:44px; color:var(--primary); margin-bottom:12px; }
.step .s-ico svg{ width:100%; height:100%; }
.step h4{ font-size:16.5px; }
.step p{ margin:8px 0 0; font-size:13px; color:var(--muted); }

/* =========================================================
   実績数（stats）
   ========================================================= */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:30px; }
.stat{ text-align:center; }
.stat .v{ font-family:var(--f-num); font-weight:800; color:#fff; font-size:clamp(40px,6vw,62px); line-height:1; letter-spacing:.01em; }
.stat .v .u{ font-size:.42em; margin-left:4px; font-weight:700; }
.stat .l{ margin-top:12px; color:rgba(255,255,255,.82); font-size:14px; font-weight:600; letter-spacing:.04em; }

/* =========================================================
   料金表
   ========================================================= */
.price-table{ width:100%; border-collapse:separate; border-spacing:0; background:#fff; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line); }
.price-table th, .price-table td{ padding:18px 24px; text-align:left; border-bottom:1px solid var(--line-soft); }
.price-table thead th{ background:var(--primary-deep); color:#fff; font-family:var(--f-head); font-size:14px; letter-spacing:.08em; }
.price-table tbody tr:last-child td{ border-bottom:none; }
.price-table tbody tr:hover{ background:var(--bg-soft); }
.price-table .item{ font-weight:700; color:var(--ink); }
.price-table .desc{ font-size:13px; color:var(--muted); }
.price-table .yen{ font-family:var(--f-num); font-weight:800; color:var(--primary-dark); white-space:nowrap; font-size:17px; }
.price-table .yen small{ font-family:var(--f-body); font-weight:600; color:var(--muted); font-size:11px; margin-left:3px; }

/* =========================================================
   施工事例 / ビフォーアフター
   ========================================================= */
.work-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.work{ background:#fff; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow-sm); transition:transform .25s, box-shadow .25s; }
.work:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.work .tag{ display:inline-block; margin:0; font-size:11.5px; font-weight:700; letter-spacing:.08em; color:var(--primary-dark); background:var(--primary-tint); padding:5px 12px; border-radius:var(--r-pill); }
.work .body{ padding:20px 22px 24px; }
.work h3{ font-size:17px; margin-top:10px; }
.work .meta{ margin-top:10px; font-size:12.5px; color:var(--muted); display:flex; gap:16px; flex-wrap:wrap; }
.work .meta b{ color:var(--ink-soft); font-family:var(--f-num); }

/* before/after slider */
.ba{ position:relative; aspect-ratio:4/3; overflow:hidden; user-select:none; touch-action:none; background:var(--bg-blue); }
.ba .layer{ position:absolute; inset:0; }
.ba .after{ z-index:1; }
.ba .before{ z-index:2; clip-path:inset(0 50% 0 0); }
.ba image-slot{ width:100%; height:100%; }
.ba .lbl{ position:absolute; top:12px; z-index:4; font-size:11px; font-weight:700; letter-spacing:.1em; color:#fff; background:rgba(20,40,70,.62); padding:4px 11px; border-radius:var(--r-pill); pointer-events:none; }
.ba .lbl.b{ left:12px; }
.ba .lbl.a{ right:12px; }
.ba .handle{ position:absolute; top:0; bottom:0; left:50%; width:3px; background:#fff; z-index:3; transform:translateX(-50%); box-shadow:0 0 0 1px rgba(20,40,70,.15); pointer-events:none; }
.ba .handle::after{
  content:"‹›"; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:42px; height:42px; border-radius:50%; background:#fff; color:var(--primary-dark);
  display:grid; place-items:center; font-size:18px; font-weight:700; letter-spacing:-2px;
  box-shadow:var(--shadow); font-family:var(--f-num);
}
.ba input[type=range]{ position:absolute; inset:0; width:100%; height:100%; opacity:0; cursor:ew-resize; z-index:5; margin:0; }

/* =========================================================
   お客様の声
   ========================================================= */
.voice-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.voice{ background:#fff; border-radius:var(--r-lg); padding:30px 28px; border:1px solid var(--line); box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.voice .stars{ color:var(--emph); font-size:15px; letter-spacing:2px; }
.voice .q{ margin:14px 0 0; font-size:15px; color:var(--ink); font-weight:500; line-height:1.95; flex:1; }
.voice .who{ margin-top:20px; padding-top:18px; border-top:1px solid var(--line-soft); display:flex; align-items:center; gap:12px; }
.voice .who image-slot{ width:44px; height:44px; flex-shrink:0; }
.voice .who .nm{ font-size:13px; font-weight:700; }
.voice .who .nm span{ display:block; font-weight:500; font-size:11.5px; color:var(--muted); }

/* =========================================================
   FAQ
   ========================================================= */
.faq-list{ max-width:840px; margin-inline:auto; display:flex; flex-direction:column; gap:14px; }
.faq{ background:#fff; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; transition:box-shadow .25s, border-color .25s; }
.faq[open]{ box-shadow:var(--shadow-sm); border-color:var(--primary-tint); }
.faq summary{ list-style:none; cursor:pointer; padding:22px 26px; display:flex; align-items:flex-start; gap:14px; font-family:var(--f-head); font-weight:700; font-size:16px; color:var(--ink); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .q{ font-family:var(--f-num); font-weight:800; color:var(--primary); flex-shrink:0; font-size:17px; }
.faq summary .tg{ margin-left:auto; flex-shrink:0; width:24px; height:24px; position:relative; transition:transform .3s; }
.faq summary .tg::before,.faq summary .tg::after{ content:""; position:absolute; top:50%; left:50%; background:var(--primary); border-radius:2px; }
.faq summary .tg::before{ width:14px; height:2px; transform:translate(-50%,-50%); }
.faq summary .tg::after{ width:2px; height:14px; transform:translate(-50%,-50%); transition:transform .3s; }
.faq[open] summary .tg::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq .a{ padding:0 26px 24px 56px; color:var(--ink-soft); font-size:14.5px; }

/* =========================================================
   CTA バンド
   ========================================================= */
.cta-band{ position:relative; overflow:hidden; background:linear-gradient(140deg,var(--primary-dark),var(--primary-deep)); color:#fff; }
.cta-band .container{ position:relative; z-index:2; text-align:center; padding-block:clamp(56px,8vw,92px); }
.cta-band h2{ font-size:clamp(26px,4vw,40px); line-height:1.4; }
.cta-band p{ margin:18px auto 0; max-width:54ch; color:rgba(255,255,255,.85); }
.cta-actions{ margin-top:34px; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.cta-band .btn-tel{ background:rgba(255,255,255,.12); color:#fff; border-color:rgba(255,255,255,.4); }
.cta-band .btn-tel:hover{ background:rgba(255,255,255,.2); }
.cta-tel{ margin-top:26px; font-family:var(--f-num); }
.cta-tel a{ font-weight:800; font-size:clamp(28px,5vw,44px); letter-spacing:.02em; display:inline-flex; align-items:center; gap:12px; white-space:nowrap; }
.cta-tel .lbl{ display:block; font-family:var(--f-body); font-size:13px; letter-spacing:.2em; color:rgba(255,255,255,.7); font-weight:600; margin-bottom:4px; }

.deco-blob{ position:absolute; border-radius:50%; filter:blur(2px); opacity:.5; }

/* =========================================================
   フッター
   ========================================================= */
.site-footer{ background:var(--primary-deep); color:rgba(255,255,255,.7); padding:64px 0 28px; }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; }
.footer-brand .brand .name b{ color:#fff; }
.footer-brand p{ margin-top:18px; font-size:13.5px; line-height:1.9; max-width:32ch; }
.footer-brand .f-tel{ margin-top:20px; font-family:var(--f-num); font-weight:800; font-size:26px; color:#fff; }
.footer-col h4{ color:#fff; font-size:14px; letter-spacing:.08em; margin-bottom:16px; }
.footer-col a{ display:block; padding:7px 0; font-size:13.5px; transition:color .2s; }
.footer-col a:hover{ color:#fff; }
.footer-bottom{ margin-top:48px; padding-top:22px; border-top:1px solid rgba(255,255,255,.14); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:12px; letter-spacing:.04em; }
.footer-bottom .f-links{ display:flex; gap:22px; flex-wrap:wrap; }

/* sticky mobile CTA bar */
.mobile-bar{ display:none; position:fixed; left:0; right:0; bottom:0; z-index:55; background:#fff; border-top:1px solid var(--line); padding:9px 12px; gap:9px; box-shadow:0 -8px 24px -16px rgba(15,45,95,.4); }
.mobile-bar .btn{ flex:1; padding:13px 10px; font-size:13.5px; }

/* =========================================================
   ページ見出し（下層ページ共通）
   ========================================================= */
.page-hero{ position:relative; background:linear-gradient(140deg,var(--primary-dark),var(--primary-deep)); color:#fff; overflow:hidden; padding:clamp(60px,9vw,96px) 0 clamp(70px,9vw,104px); }
.page-hero .container{ position:relative; z-index:2; }
.page-hero .eyebrow{ color:#fff; }
.page-hero .eyebrow::before{ background:var(--accent); }
.page-hero h1{ font-size:clamp(30px,5vw,52px); margin-top:16px; }
.page-hero .crumbs{ margin-top:20px; font-size:12.5px; color:rgba(255,255,255,.7); display:flex; gap:8px; }
.page-hero .crumbs a:hover{ color:#fff; }

/* helper */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,64px); align-items:center; }
.prose p{ color:var(--ink-soft); margin:0 0 16px; }
.lead{ font-size:18px; color:var(--ink); font-weight:500; line-height:1.9; }

/* =========================================================
   ヒーロー（TOP）
   ========================================================= */
.hero{ position:relative; background:var(--bg); padding-top:clamp(40px,6vw,72px); overflow:hidden; }
.hero-bg{
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(900px 500px at 88% -10%, var(--primary-tint), transparent 70%),
    radial-gradient(700px 480px at 8% 110%, oklch(0.95 0.03 215), transparent 70%);
}
.hero-inner{ position:relative; z-index:2; display:grid; grid-template-columns:1.06fr .94fr; gap:clamp(30px,5vw,68px); align-items:center; padding-bottom:clamp(50px,7vw,86px); }
.hero-copy h1{ font-size:clamp(31px,5.1vw,58px); font-weight:900; line-height:1.28; margin-top:18px; letter-spacing:.01em; word-break:auto-phrase; line-break:strict; }
.hero-copy h1 .acc{ color:var(--primary); position:relative; white-space:nowrap; }
.hero-copy h1 .acc::after{ content:""; position:absolute; left:0; right:0; bottom:.08em; height:.22em; background:oklch(0.85 0.08 215 / .6); z-index:-1; border-radius:4px; }
.hero-copy h1 .hl-pop{
  position:relative; display:inline-block; white-space:nowrap;
  color:#fff; font-weight:900; padding:.02em .2em 0; margin:0 .04em;
  z-index:0; -webkit-box-decoration-break:clone; box-decoration-break:clone;
  text-shadow:0 1px 8px rgba(15,45,95,.18);
}
.hero-copy h1 .hl-pop::before{
  content:""; position:absolute; inset:.1em -.04em .04em;
  background:linear-gradient(102deg, var(--primary) 8%, var(--accent-deep) 96%);
  border-radius:.34em .42em .3em .46em; transform:rotate(-1.4deg);
  box-shadow:0 12px 26px -12px var(--primary); z-index:-1;
}
.hero-copy h1 .hl-pop::after{
  content:""; position:absolute; right:-.34em; top:-.12em; width:.34em; height:.34em;
  border-radius:50%; background:var(--accent); opacity:.55; z-index:-1;
}
.hero-lead{ margin-top:22px; font-size:clamp(15px,1.6vw,17px); color:var(--ink-soft); max-width:38ch; line-height:1.95; word-break:auto-phrase; line-break:strict; text-wrap:pretty; }

.hero-trust{ list-style:none; margin:28px 0 0; padding:0; display:flex; gap:12px; flex-wrap:wrap; }
.hero-trust li{
  display:flex; flex-direction:column; align-items:center; text-align:center; gap:7px;
  background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:14px 16px;
  font-family:var(--f-head); font-weight:700; font-size:12.5px; color:var(--ink); line-height:1.3;
  box-shadow:var(--shadow-sm); min-width:96px;
}
.hero-trust li svg{ width:24px; height:24px; color:var(--primary); }

.hero-actions{ margin-top:30px; display:flex; gap:13px; flex-wrap:wrap; }
.hero-note{ margin-top:18px; font-size:12px; color:var(--muted); max-width:42ch; line-height:1.7; }

.hero-visual{ position:relative; }
.hero-photo{ width:100%; aspect-ratio:4/4.4; box-shadow:var(--shadow-lg); }
.hero-badge{
  position:absolute; background:#fff; border-radius:16px; padding:15px 19px;
  box-shadow:var(--shadow-lg); border:1px solid var(--line-soft);
}
.hero-badge .bv{ font-family:var(--f-num); font-weight:800; font-size:30px; color:var(--primary-dark); line-height:1; }
.hero-badge .bu{ font-family:var(--f-num); font-weight:800; font-size:16px; color:var(--primary-dark); margin-left:2px; }
.hero-badge .bl{ display:block; margin-top:4px; font-size:11.5px; color:var(--muted); font-weight:600; }
.hero-badge .stars{ color:var(--emph); font-size:14px; letter-spacing:1px; display:block; }
.hero-badge .bl b{ color:var(--ink); font-family:var(--f-num); }
.float-a{ top:24px; left:-26px; animation:floaty 5s ease-in-out infinite; }
.float-b{ bottom:30px; right:-22px; animation:floaty 5s ease-in-out infinite .8s; }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-9px); } }
.hero-wave{ position:relative; z-index:1; margin-top:-2px; }

@media (prefers-reduced-motion:reduce){ .float-a,.float-b{ animation:none; } }

.sec-foot{ margin-top:clamp(34px,4vw,52px); }
.sec-foot.center{ text-align:center; }

/* =========================================================
   実績数バンド
   ========================================================= */
.stats-band{ position:relative; overflow:hidden; }
.stats-bg{ position:absolute; inset:0; z-index:0; background:linear-gradient(135deg,var(--primary-dark),var(--primary-deep)); }
.stats-bg::after{ content:""; position:absolute; inset:0; background:radial-gradient(600px 300px at 80% 0%, oklch(0.6 0.13 215 / .5), transparent 70%); }

/* =========================================================
   料金フッター注記
   ========================================================= */
.price-foot{ margin-top:18px; font-size:12.5px; color:var(--muted); line-height:1.8; }

/* =========================================================
   対応エリア
   ========================================================= */
.area-list{ list-style:none; padding:0; margin:24px 0 0; display:grid; grid-template-columns:repeat(4,1fr); gap:10px 14px; }
.area-list li{ position:relative; padding-left:20px; font-size:14px; font-weight:600; color:var(--ink-soft); }
.area-list li::before{ content:""; position:absolute; left:2px; top:.62em; width:7px; height:7px; border-radius:50%; background:var(--accent); }
.area-map{ position:relative; }
.area-map image-slot{ width:100%; aspect-ratio:4/3.4; box-shadow:var(--shadow); }
.area-gmap{ width:100%; aspect-ratio:4/3.4; border:0; display:block; border-radius:var(--r-lg); box-shadow:var(--shadow); }
.map-pin{ position:absolute; background:#fff; border-radius:var(--r-pill); padding:6px 13px 6px 9px; font-size:12px; font-weight:700; color:var(--primary-dark); box-shadow:var(--shadow); display:flex; align-items:center; gap:7px; }
.map-pin span{ width:9px; height:9px; border-radius:50%; background:var(--primary); box-shadow:0 0 0 4px var(--primary-tint); }
.map-pin.p1{ top:30%; left:18%; }
.map-pin.p2{ bottom:22%; left:30%; }
.map-pin.p3{ top:20%; right:16%; }

@media (max-width:920px){
  .hero-inner{ grid-template-columns:1fr; }
  .hero-visual{ max-width:460px; margin-inline:auto; order:-1; }
  .hero-photo{ aspect-ratio:4/3.2; }
  .area-list{ grid-template-columns:repeat(3,1fr); }
}

/* =========================================================
   下層ページ：サービス詳細
   ========================================================= */
.svc-row{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,60px); align-items:center; padding:clamp(40px,6vw,72px) 0; border-bottom:1px solid var(--line-soft); }
.svc-row:last-child{ border-bottom:none; }
.svc-row.flip .svc-row-media{ order:2; }
.svc-row-media{ position:relative; }
.svc-row-media image-slot{ width:100%; aspect-ratio:4/3; box-shadow:var(--shadow); }
.svc-row-media .tagnum{ position:absolute; top:-16px; left:-12px; width:64px; height:64px; border-radius:18px; background:linear-gradient(150deg,var(--primary),var(--primary-dark)); color:#fff; display:grid; place-items:center; font-family:var(--f-num); font-weight:800; font-size:24px; box-shadow:var(--shadow); }
.svc-row-body .eyebrow{ margin-bottom:10px; }
.svc-row-body h2{ font-size:clamp(23px,3vw,30px); }
.svc-row-body .price-line{ margin-top:14px; font-family:var(--f-num); font-weight:800; color:var(--primary-dark); font-size:16px; }
.svc-row-body .price-line b{ font-size:28px; }
.svc-row-body p{ margin:16px 0 0; color:var(--ink-soft); font-size:15px; }
.chip-list{ list-style:none; padding:0; margin:20px 0 0; display:flex; flex-wrap:wrap; gap:9px; }
.chip-list li{ font-size:13px; font-weight:600; color:var(--primary-dark); background:var(--primary-tint); padding:7px 14px; border-radius:var(--r-pill); }

/* =========================================================
   料金ページ
   ========================================================= */
.price-cat{ margin-top:clamp(40px,5vw,60px); }
.price-cat:first-of-type{ margin-top:0; }
.price-cat h2{ display:flex; align-items:center; gap:13px; font-size:22px; margin-bottom:20px; }
.price-cat h2 .ic{ width:44px; height:44px; border-radius:13px; background:var(--primary-tint); color:var(--primary-dark); display:grid; place-items:center; flex-shrink:0; }
.price-cat h2 .ic svg{ width:24px; height:24px; }
.note-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.note-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:28px 26px; box-shadow:var(--shadow-sm); }
.note-card .ic{ display:grid; place-items:center; width:48px; height:48px; color:var(--primary); margin-bottom:14px; }
.note-card .ic svg{ width:100%; height:100%; }
.note-card h3{ font-size:18px; }
.note-card p{ margin:10px 0 0; font-size:14px; color:var(--ink-soft); }

/* =========================================================
   会社概要
   ========================================================= */
.outline-table{ width:100%; border-collapse:collapse; background:#fff; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line); }
.outline-table th, .outline-table td{ text-align:left; padding:20px 26px; border-bottom:1px solid var(--line-soft); vertical-align:top; font-size:15px; }
.outline-table tr:last-child th, .outline-table tr:last-child td{ border-bottom:none; }
.outline-table th{ width:30%; background:var(--bg-soft); font-family:var(--f-head); font-weight:700; color:var(--ink); letter-spacing:.04em; }
.outline-table td{ color:var(--ink-soft); }
.promise-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.promise{ text-align:center; padding:34px 26px; background:#fff; border-radius:var(--r-lg); border:1px solid var(--line-soft); box-shadow:var(--shadow-sm); }
.promise .ic{ display:grid; place-items:center; width:56px; height:56px; color:var(--primary); margin:0 auto 16px; }
.promise .ic svg{ width:100%; height:100%; }
.promise h3{ font-size:19px; }
.promise p{ margin:10px 0 0; font-size:14px; color:var(--ink-soft); }

/* =========================================================
   お問い合わせ
   ========================================================= */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,52px); align-items:start; }
.contact-methods{ display:flex; flex-direction:column; gap:16px; }
.method{ display:flex; gap:18px; align-items:center; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:24px 26px; box-shadow:var(--shadow-sm); }
.method .m-ico{ width:56px; height:56px; border-radius:16px; display:grid; place-items:center; flex-shrink:0; color:#fff; }
.method .m-ico.tel{ background:linear-gradient(150deg,var(--primary),var(--primary-dark)); }
.method .m-ico.line{ background:var(--line-green); }
.method .m-ico.mail{ background:linear-gradient(150deg,var(--accent),var(--accent-deep)); }
.method .m-ico svg{ width:28px; height:28px; }
.method h3{ font-size:17px; }
.method .big{ font-family:var(--f-num); font-weight:800; font-size:26px; color:var(--primary-dark); line-height:1.1; margin-top:4px; }
.method p{ margin:5px 0 0; font-size:12.5px; color:var(--muted); }
.method .go{ margin-left:auto; }

.form-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(26px,4vw,40px); box-shadow:var(--shadow); }
.field{ margin-bottom:20px; }
.field label{ display:block; font-family:var(--f-head); font-weight:700; font-size:14px; margin-bottom:8px; }
.field label .req{ font-size:11px; color:#fff; background:var(--emph); padding:2px 8px; border-radius:var(--r-pill); margin-left:8px; font-family:var(--f-body); font-weight:700; }
.field label .opt{ font-size:11px; color:var(--muted); margin-left:8px; font-weight:600; }
.field input, .field textarea, .field select{
  width:100%; padding:14px 16px; border:1.5px solid var(--line); border-radius:var(--r);
  font-family:var(--f-body); font-size:15px; color:var(--ink); background:var(--bg); transition:border-color .2s, box-shadow .2s;
}
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--primary); box-shadow:0 0 0 4px var(--primary-tint); }
.field textarea{ resize:vertical; min-height:120px; line-height:1.7; }
.form-note{ font-size:12px; color:var(--muted); margin:0 0 22px; line-height:1.7; }
.form-done{ display:none; text-align:center; padding:30px 20px; }
.form-done.show{ display:block; }
.form-done .ic{ display:grid; place-items:center; width:64px; height:64px; margin:0 auto 18px; color:var(--line-green); }
.form-done .ic svg{ width:100%; height:100%; }
.form-done h3{ font-size:22px; }
.form-done p{ margin:12px 0 0; color:var(--ink-soft); }

@media (max-width:920px){
  .svc-row{ grid-template-columns:1fr; }
  .svc-row.flip .svc-row-media{ order:0; }
  .note-cards, .promise-grid{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .outline-table th{ width:34%; }
}

/* =========================================================
   レスポンシブ
   ========================================================= */
@media (max-width:1080px){
  .card-grid{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); }
  .footer-top{ grid-template-columns:1fr 1fr; }
}
@media (max-width:1024px){
  .nav, .header-cta .tel-mini{ display:none; }
  .menu-toggle{ display:flex; }
  .header-cta{ margin-left:auto; }
  .nav.open{
    display:flex; flex-direction:column; gap:4px; position:absolute; top:74px; left:0; right:0;
    background:#fff; padding:16px var(--gutter) 24px; box-shadow:var(--shadow); border-top:1px solid var(--line);
  }
  .nav.open a{ padding:14px 14px; font-size:16px; }
  .reason-grid, .work-grid, .voice-grid{ grid-template-columns:1fr; }
  .reason-grid{ gap:18px; }
  .split{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:repeat(2,1fr); gap:34px 20px; }
  .mobile-bar{ display:flex; }
  body{ padding-bottom:72px; }
}
@media (max-width:560px){
  .card-grid{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr; gap:30px; }
  .header-cta .btn span.lbl-full{ display:none; }
  .work-grid, .voice-grid{ gap:16px; }
}
