/* =========================================================
   鈴木Web製作所 制作サンプル：遺品整理（スタンダード・5ページ）
   /samples/ihinseiri/ 共通スタイル
   noindex ／ 架空・汎用の見本
   ========================================================= */
:root{
  --bg:#f7f5ef; --bg-card:#ffffff; --bg-soft:#eee9dd;
  --ink:#1f2a24; --ink-soft:#566058; --ink-sub:#6b7269;
  --green-deep:#2f5d4a; --green:#3f7a60; --green-soft:#7da994;
  --accent:#b08a3e; --accent-bg:#f0e7d2;
  --line:#dcd9cf; --line-green:#06C755;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip}
body{font-family:'Zen Kaku Gothic New',sans-serif;background:var(--bg);color:var(--ink);line-height:1.9;overflow-x:clip;-webkit-font-smoothing:antialiased;background-image:radial-gradient(rgba(47,93,74,.022) 1px,transparent 1px);background-size:22px 22px}
h1,h2,h3{font-family:'Noto Serif JP',serif;font-weight:500;letter-spacing:.04em;line-height:1.5}
img{max-width:100%;display:block}
a{color:inherit}
.container{max-width:1040px;margin:0 auto;padding:0 1.5rem}
section{padding:4.5rem 0}
@media(max-width:720px){section{padding:3rem 0}}
.center{text-align:center}
.lead{color:var(--ink-soft);font-size:1.02rem}
.sec-head{text-align:center;margin-bottom:2.5rem}
.sec-head .en{display:block;font-size:.72rem;letter-spacing:.25em;color:var(--green-soft);margin-bottom:.5rem;text-transform:uppercase}
.sec-head h2{font-size:1.65rem;color:var(--green-deep);position:relative;display:inline-block;padding-bottom:.65rem}
.sec-head h2::after{content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:34px;height:2px;background:var(--accent);border-radius:2px}
.trust .sec-head h2::after{background:var(--green-soft)}
@media(max-width:720px){.sec-head h2{font-size:1.35rem}}

/* サンプルバー */
.sample-bar{background:var(--green-deep);color:#fff;font-size:.78rem;text-align:center;padding:.5rem 1rem;letter-spacing:.04em;position:relative;z-index:200}
.sample-bar strong{color:#ffe6a8;font-weight:700}

/* ヘッダー */
header.site{background:rgba(255,255,255,.98);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:150;-webkit-backdrop-filter:saturate(1.1) blur(2px);backdrop-filter:saturate(1.1) blur(2px)}
header.site .inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1.5rem;max-width:1040px;margin:0 auto}
.brand{font-family:'Noto Serif JP',serif;color:var(--green-deep);text-decoration:none;font-size:1.18rem;font-weight:600;white-space:nowrap}
.brand .sub{display:block;font-size:.62rem;color:var(--ink-sub);letter-spacing:.12em;font-family:'Zen Kaku Gothic New',sans-serif;font-weight:400}
nav.global{display:flex;gap:1.3rem;flex-wrap:wrap}
nav.global a{color:var(--ink);text-decoration:none;font-size:.86rem;padding:.2rem 0;border-bottom:2px solid transparent;white-space:nowrap}
nav.global a:hover,nav.global a.active{border-bottom-color:var(--green);color:var(--green-deep)}

/* ハンバーガー */
.nav-toggle{display:none;width:44px;height:44px;flex-direction:column;justify-content:center;align-items:center;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--green-deep);border-radius:2px;transition:transform .25s,opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(31,42,36,.45);z-index:160}
.nav-overlay.open{display:block}
.mobile-nav{position:fixed;top:0;right:0;height:100%;width:74%;max-width:300px;background:var(--bg-card);z-index:170;transform:translateX(100%);transition:transform .28s ease;display:flex;flex-direction:column;padding:4.5rem 0 1.5rem;box-shadow:-6px 0 24px rgba(0,0,0,.12)}
.mobile-nav[data-open="true"]{transform:translateX(0)}
.mobile-nav a{padding:1rem 1.6rem;text-decoration:none;color:var(--ink);font-size:1rem;border-bottom:1px solid var(--line)}
.mobile-nav a.active{color:var(--green-deep);font-weight:600;background:var(--bg-soft)}
.mobile-nav .mn-cta{display:flex;gap:.6rem;padding:1.2rem 1.6rem}
.mobile-nav .mn-cta .btn{flex:1;justify-content:center;padding:.7rem;font-size:.88rem}
@media(max-width:860px){
  nav.global{display:none}
  .nav-toggle{display:flex}
  .brand{font-size:1.05rem}
}
@media(min-width:861px){.mobile-nav,.nav-overlay{display:none!important}}

/* ボタン */
.btn{display:inline-flex;align-items:center;gap:.4rem;border-radius:6px;font-weight:600;font-size:.95rem;padding:.85rem 1.6rem;text-decoration:none;border:none;cursor:not-allowed}
.btn.primary{background:var(--accent);color:#fff}
.btn.line{background:var(--line-green);color:#fff}
.btn.ghost{background:rgba(255,255,255,.9);color:var(--green-deep)}
.btn.outline{background:transparent;border:1px solid var(--green);color:var(--green-deep);cursor:pointer}
.hero-cta{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap}

/* ヒーロー（トップ・3枚スライド） */
.hero{position:relative;min-height:60vh;display:flex;align-items:center;color:#fff;text-align:center}
.hero .hero-slides{position:absolute;inset:0;overflow:hidden}
.hero .hero-slides img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;animation:heroKen 21s infinite;transform-origin:center;will-change:opacity,transform}
.hero .hero-slides img:first-child{opacity:1}
.hero .hero-slides img:nth-child(2){animation-delay:7s}
.hero .hero-slides img:nth-child(3){animation-delay:14s}
@keyframes heroKen{0%{opacity:1;transform:scale(1)}30%{opacity:1;transform:scale(1.08)}34%{opacity:0;transform:scale(1.09)}100%{opacity:0;transform:scale(1.09)}}
@media(prefers-reduced-motion:reduce){.hero .hero-slides img{animation:none;opacity:0}.hero .hero-slides img:first-child{opacity:1}}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(31,42,36,.45),rgba(47,93,74,.62));z-index:1}
.hero .inner{position:relative;z-index:2;max-width:760px;margin:0 auto;padding:4rem 1.5rem}
.hero .eyebrow{font-size:.85rem;letter-spacing:.18em;margin-bottom:1rem;color:#ffe6a8}
.hero h1{font-size:2.1rem;color:#fff;margin-bottom:1rem;text-shadow:0 2px 18px rgba(0,0,0,.25)}
.hero p{font-size:1.05rem;margin-bottom:1.8rem;text-shadow:0 1px 12px rgba(0,0,0,.3)}
.hero .badges{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.8rem}
.hero .badge{background:rgba(255,255,255,.92);color:var(--green-deep);border-radius:999px;font-size:.8rem;font-weight:600;padding:.4rem .9rem}
@media(max-width:720px){
  .hero h1{font-size:1.55rem}.hero p{font-size:.98rem}
}
/* ヒーロー：PC=横版(ds)／スマホ=縦版(ms) を出し分け */
.hero-slides.ms{display:none}
@media(max-width:760px){
  .hero-slides.ds{display:none}
  .hero-slides.ms{display:block}
  /* 縦ヒーローは高さを取り、文字＋ボタンを下寄りに置いて上に写真を見せる */
  .hero{min-height:92vh;align-items:flex-end}
  .hero .inner{padding:2rem 1.5rem 2.4rem}
}

/* 下層ページのページヘッダー */
.page-hero{position:relative;color:#fff;text-align:center;padding:3.2rem 1.5rem}
.page-hero::before{content:"";position:absolute;inset:0;background:var(--green-deep) url('images/hero-3.jpg') center/cover;opacity:1;z-index:0}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(31,42,36,.55),rgba(47,93,74,.7));z-index:1}
.page-hero .inner{position:relative;z-index:2}
.page-hero .en{display:block;font-size:.72rem;letter-spacing:.25em;color:#ffe6a8;margin-bottom:.4rem;text-transform:uppercase}
.page-hero h1{font-size:1.8rem;color:#fff}
@media(max-width:720px){.page-hero h1{font-size:1.4rem}}

/* パンくず */
.crumb{font-size:.78rem;color:var(--ink-sub);padding:.9rem 0}
.crumb a{color:var(--green);text-decoration:none}
.crumb a:hover{text-decoration:underline}

/* お悩み */
.worries{background:var(--bg-soft)}
.worry-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-top:1.5rem}
.worry{background:var(--bg-card);border:1px solid var(--line);border-radius:10px;padding:1.3rem 1.4rem;font-size:.97rem;position:relative;box-shadow:0 1px 3px rgba(31,42,36,.05)}
.worry::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--green-soft);margin-right:.6rem;vertical-align:middle}

/* 状況別 */
.sit-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:.8rem;margin-top:1rem}
.sit{display:flex;gap:.6rem;align-items:flex-start;background:var(--bg-card);border:1px solid var(--line);border-radius:10px;padding:1rem 1.2rem;font-size:.95rem;box-shadow:0 1px 3px rgba(31,42,36,.05)}
.sit svg{flex:0 0 auto;width:20px;height:20px;margin-top:.2rem;stroke:var(--green);fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}

/* 理由 */
.reasons{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.4rem;margin-top:1rem}
.reason{background:var(--bg-card);border:1px solid var(--line);border-radius:12px;padding:1.8rem 1.5rem;text-align:center;box-shadow:0 1px 3px rgba(31,42,36,.05)}
.reason .num{font-family:'Noto Serif JP',serif;color:var(--accent);font-size:1.4rem;display:block;margin-bottom:.6rem}
.reason h3{font-size:1.12rem;color:var(--green-deep);margin-bottom:.6rem}
.reason p{font-size:.92rem;color:var(--ink-soft)}

/* 料金 */
.price{background:var(--bg-soft)}
.price-table{width:100%;border-collapse:collapse;background:var(--bg-card);border-radius:10px;overflow:hidden;margin-top:1rem;font-size:.96rem}
.price-table th,.price-table td{padding:.85rem 1rem;border-bottom:1px solid var(--line);text-align:left}
.price-table thead th{background:var(--green-deep);color:#fff;font-weight:600}
.price-table tbody tr:last-child td{border-bottom:none}
.price-table td.amt{text-align:right;font-weight:600;color:var(--green-deep);white-space:nowrap}
.note{margin-top:1.1rem;font-size:.86rem;color:var(--ink-sub);background:var(--bg-card);border-left:3px solid var(--green-soft);padding:.9rem 1.1rem;border-radius:0 8px 8px 0}

/* 流れ */
.flow{counter-reset:step;display:grid;gap:1rem;margin-top:1rem}
.step{display:flex;gap:1rem;align-items:flex-start;background:var(--bg-card);border:1px solid var(--line);border-radius:10px;padding:1.2rem 1.3rem}
.step .n{counter-increment:step;flex:0 0 auto;width:38px;height:38px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Noto Serif JP',serif}
.step .n::before{content:counter(step)}
.step-ico{width:40px;height:40px;object-fit:contain;flex:0 0 auto;align-self:center}
.step h3{font-size:1.05rem;color:var(--green-deep);margin-bottom:.2rem}
.step p{font-size:.9rem;color:var(--ink-soft)}

/* サービス */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr}}
.svc{background:var(--bg-card);border:1px solid var(--line);border-radius:10px;padding:1.3rem 1.4rem;box-shadow:0 1px 3px rgba(31,42,36,.05)}
.svc h3{font-size:1.05rem;color:var(--green-deep);margin-bottom:.4rem}
.svc p{font-size:.88rem;color:var(--ink-soft)}
.svc-ico{width:46px;height:46px;object-fit:contain;display:block;margin-bottom:.7rem}

/* LINE見積 */
.linebox{background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:1.7rem 1.5rem;max-width:720px;margin:0 auto;text-align:center;box-shadow:0 1px 3px rgba(31,42,36,.05)}
.linebox .lb-icon{width:46px;height:46px;border-radius:11px;background:var(--line-green);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem;margin-bottom:.5rem}
.linebox h3{color:var(--green-deep);font-size:1.2rem;margin-bottom:.5rem}
.linebox p{font-size:.95rem;color:var(--ink-soft);margin:.3rem 0}

/* 信頼 */
.trust{background:var(--green-deep);color:#fff}
.trust .sec-head h2{color:#fff}
.trust .sec-head .en{color:var(--green-soft)}
.trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1rem;margin-top:1rem}
.trust-item{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);border-radius:10px;padding:1.3rem}
.trust-ico{width:38px;height:38px;object-fit:contain;display:block;margin-bottom:.6rem;filter:brightness(0) invert(1);opacity:.92}
.trust-item h3{font-size:1.02rem;color:#ffe6a8;margin-bottom:.4rem}
.trust-item p{font-size:.88rem;color:#e8efe9}
.trust-item .ex{display:block;font-size:.76rem;color:#cfe0d6;margin-top:.35rem}
.trust .disclaimer{margin-top:1.4rem;font-size:.8rem;color:#cfe0d6;text-align:center}

/* 事例 */
.cases{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem;margin-top:1rem}
.case{background:var(--bg-card);border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:0 1px 3px rgba(31,42,36,.05)}
.case .cimg{width:100%;height:200px;object-fit:cover;display:block}
.case .body{padding:1.1rem 1.3rem}
.case .body h3{font-size:1rem;color:var(--green-deep);margin-bottom:.3rem}
.case dl{margin:.4rem 0 0;font-size:.86rem;display:grid;grid-template-columns:auto 1fr;gap:.1rem .8rem}
.case dl dt{color:var(--green-deep);font-weight:600}
.case dl dd{color:var(--ink-soft);margin:0}
.cnote{font-size:.78rem;color:var(--ink-sub);margin-top:.5rem}
.tag{display:inline-block;background:var(--accent-bg);color:var(--green-deep);font-size:.72rem;padding:.15rem .6rem;border-radius:4px;margin-bottom:.5rem}

/* 口コミ枠 */
.review{background:var(--bg-card);border:1px solid var(--line);border-radius:12px;padding:1.6rem;text-align:center;max-width:560px;margin:0 auto 1.6rem;box-shadow:0 1px 3px rgba(31,42,36,.05)}
.review .stars{color:var(--accent);font-size:1.5rem;letter-spacing:.12em}
.review .rv-lead{font-size:.9rem;color:var(--ink-soft);margin-bottom:.3rem}
.review .rv-eg{font-size:1.02rem;color:var(--green-deep);font-weight:600;margin:.2rem 0}
.review .ex{display:block;font-size:.76rem;color:var(--ink-sub);margin-top:.35rem}

/* 声 */
.voice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-top:1rem}
.voice{background:var(--bg-card);border:1px solid var(--line);border-radius:10px;padding:1.3rem;box-shadow:0 1px 3px rgba(31,42,36,.05)}
.voice p{font-size:.92rem;color:var(--ink)}
.voice .who{margin-top:.7rem;font-size:.8rem;color:var(--ink-sub)}

/* お知らせ */
.news-list{margin-top:1rem;border-top:1px solid var(--line)}
.news-item{display:flex;gap:1rem;align-items:baseline;padding:.9rem .2rem;border-bottom:1px solid var(--line);font-size:.93rem}
.news-item time{flex:0 0 auto;color:var(--ink-sub);font-size:.82rem;width:6.5rem}
.news-item .nt{display:inline-block;background:var(--accent-bg);color:var(--green-deep);font-size:.7rem;padding:.1rem .5rem;border-radius:3px;margin-right:.5rem}

/* FAQ */
details{background:var(--bg-card);border:1px solid var(--line);border-radius:8px;margin-bottom:.7rem;padding:0 1.2rem}
details summary{cursor:pointer;padding:1rem 0;font-weight:500;color:var(--green-deep);list-style:none;position:relative;padding-right:1.5rem}
details summary::-webkit-details-marker{display:none}
details summary::after{content:"＋";position:absolute;right:0;color:var(--green-soft)}
details[open] summary::after{content:"－"}
details .ans{padding:0 0 1.1rem;font-size:.92rem;color:var(--ink-soft)}

/* 挨拶 */
.greeting{display:grid;grid-template-columns:200px 1fr;gap:2rem;align-items:center}
.greeting img{height:240px;width:100%;object-fit:cover;object-position:center top;border-radius:12px}
.greeting p{font-size:.95rem;color:var(--ink-soft)}
.ex{display:block;font-size:.76rem;color:var(--ink-sub);margin-top:.35rem}
@media(max-width:680px){.greeting{grid-template-columns:1fr}}

/* 会社概要テーブル */
.info-table{width:100%;border-collapse:collapse;margin-top:1rem;font-size:.92rem;background:var(--bg-card);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.info-table th,.info-table td{padding:.8rem 1rem;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.info-table th{background:var(--bg-soft);color:var(--green-deep);width:30%;font-weight:600;white-space:nowrap}
.info-table tr:last-child th,.info-table tr:last-child td{border-bottom:none}

/* CTA帯 / 問い合わせ */
.contact{background:var(--green-deep);color:#fff;text-align:center}
.contact h2{color:#fff;font-size:1.6rem;margin-bottom:.8rem}
.contact p{color:#e8efe9;margin-bottom:1.6rem}
.contact .hero-cta{margin-bottom:1rem}
.contact .small{font-size:.8rem;color:#cfe0d6}

/* 下層への誘導カード */
.next-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:1rem}
.next-card{display:block;background:var(--bg-card);border:1px solid var(--line);border-radius:10px;padding:1.2rem 1.3rem;text-decoration:none;color:var(--ink);box-shadow:0 1px 3px rgba(31,42,36,.05);transition:transform .2s}
.next-card:hover{transform:translateY(-3px)}
.next-card .en{font-size:.68rem;letter-spacing:.2em;color:var(--green-soft);text-transform:uppercase}
.next-card h3{font-size:1.02rem;color:var(--green-deep);margin:.2rem 0}
.next-card p{font-size:.84rem;color:var(--ink-soft)}

/* サンプル注記枠 */
.about-box .worry-grid{margin-top:1rem}

/* フッター */
footer.site{background:#1f2a24;color:#c9cfc9;font-size:.82rem;padding:2.4rem 1.5rem;text-align:center}
footer.site .sample-foot{color:#ffe6a8;margin-bottom:.7rem}
footer.site nav.fnav{display:flex;gap:1.2rem;justify-content:center;flex-wrap:wrap;margin-bottom:.9rem}
footer.site nav.fnav a{color:#c9cfc9;text-decoration:none;font-size:.82rem}
footer.site nav.fnav a:hover{color:#ffe6a8}
footer.site a{color:#ffe6a8}

/* 固定CTA（スマホ） */
.fixed-cta{position:fixed;left:0;right:0;bottom:0;z-index:140;display:none;gap:.5rem;padding:.55rem .7rem;background:rgba(255,255,255,.97);border-top:1px solid var(--line);box-shadow:0 -4px 14px rgba(0,0,0,.08)}
.fixed-cta .btn{flex:1;justify-content:center;padding:.75rem;font-size:.9rem}
@media(max-width:860px){
  .fixed-cta{display:flex;transform:translateY(120%);transition:transform .28s ease;will-change:transform}
  .fixed-cta.visible{transform:translateY(0)}
  /* 固定CTAが本文下部にかぶらないよう、各セクションと最下部に余白 */
  section{padding-bottom:4rem}
  body{padding-bottom:3rem}
}
@media(max-width:480px){.head-cta{display:none}}

/* ===== 新デザイン上乗せ（想い整理のそら）===== */

/* 見出し脇の葉装飾 */
.sec-head.leaf{position:relative}
.sec-head.leaf::before,.sec-head.leaf::after{content:"";position:absolute;top:50%;width:62px;height:42px;transform:translateY(-60%);background:url('images/icons/add-31.png') center/contain no-repeat;opacity:.8;pointer-events:none}
.sec-head.leaf::before{right:calc(50% + 7.5rem)}
.sec-head.leaf::after{left:calc(50% + 7.5rem);transform:translateY(-60%) scaleX(-1)}
@media(max-width:760px){.sec-head.leaf::before,.sec-head.leaf::after{display:none}}

/* 特長ストリップ */
.feature-strip{background:var(--green-deep);padding:1.1rem 0}
.feature-strip .features{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;text-align:center}
.feature-strip li{display:flex;flex-direction:column;align-items:center;gap:.4rem;color:#fff}
.feature-strip li img{width:38px;height:38px;object-fit:contain;filter:brightness(0) invert(1)}
.feature-strip li span{font-size:.86rem;font-weight:600;letter-spacing:.02em}
@media(max-width:620px){.feature-strip .features{grid-template-columns:repeat(2,1fr);gap:1rem}.feature-strip li span{font-size:.82rem}}

/* お悩み（アイコン付きカード） */
.worry{display:flex;align-items:center;gap:.9rem;text-align:left}
.worry::before{display:none}
.worry img{flex:0 0 auto;width:46px;height:46px;object-fit:contain}
.worry p{font-size:.96rem;margin:0;line-height:1.6}

/* 状況別（写真カード） */
.sit-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.3rem;margin-top:1rem}
.sit-card{background:var(--bg-card);border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:0 2px 10px rgba(31,42,36,.06);display:flex;flex-direction:column}
.sit-card img{width:100%;height:170px;object-fit:cover}
.sit-card .body{padding:1.1rem 1.2rem 1.3rem}
.sit-card h3{font-size:1.04rem;color:var(--green-deep);margin-bottom:.45rem}
.sit-card p{font-size:.88rem;color:var(--ink-soft);line-height:1.75}

/* 選ばれる理由（写真＋文・交互） */
.reason-rows{display:flex;flex-direction:column;gap:2rem;margin-top:1rem}
.reason-row{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}
.reason-row .rr-img img{width:100%;height:280px;object-fit:cover;border-radius:14px;box-shadow:0 3px 14px rgba(31,42,36,.1)}
.reason-row.rev .rr-img{order:2}
.reason-row .rr-img.person img{object-fit:contain;background:#ece5d6}
.reason-row .rr-text .num{font-family:'Noto Serif JP',serif;color:var(--accent);font-size:1.6rem;display:inline-block;margin-bottom:.3rem;padding-bottom:.2rem;border-bottom:2px solid var(--accent-bg)}
.reason-row .rr-text h3{font-size:1.3rem;color:var(--green-deep);margin-bottom:.6rem}
.reason-row .rr-text p{font-size:.95rem;color:var(--ink-soft);line-height:1.95}
@media(max-width:760px){
  .reason-row{grid-template-columns:1fr;gap:1rem}
  .reason-row.rev .rr-img{order:0}
  .reason-row .rr-img img{height:220px}
}

/* 作業の流れ（丸アイコン） */
.flow-circles{list-style:none;display:grid;grid-template-columns:repeat(6,1fr);gap:.8rem;margin-top:1rem;counter-reset:none}
.flow-circles li{position:relative;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.flow-circles li:not(:last-child)::after{content:"";position:absolute;top:38px;right:-.55rem;width:1.1rem;height:2px;background:var(--green-soft)}
.flow-circles .fc-ico{width:78px;height:78px;border-radius:50%;background:var(--accent-bg);border:1px solid var(--line);display:flex;align-items:center;justify-content:center}
.flow-circles .fc-ico img{width:42px;height:42px;object-fit:contain}
.flow-circles .fc-n{position:absolute;top:-4px;left:calc(50% + 18px);width:22px;height:22px;border-radius:50%;background:var(--green-deep);color:#fff;font-size:.72rem;display:flex;align-items:center;justify-content:center;font-family:'Noto Serif JP',serif}
.flow-circles b{font-size:.82rem;color:var(--green-deep);font-weight:600;line-height:1.45}
@media(max-width:760px){
  /* スマホは縦1列のタイムライン（番号→アイコン→ラベルを上から順に・縦線でつなぐ＝順番が一目で分かる） */
  .flow-circles{grid-template-columns:1fr;gap:.1rem;max-width:360px;margin:1rem auto 0}
  .flow-circles li{flex-direction:row;align-items:center;justify-content:flex-start;gap:1.1rem;text-align:left;padding:.6rem 0}
  .flow-circles .fc-ico{width:62px;height:62px}
  .flow-circles .fc-ico img{width:32px;height:32px}
  .flow-circles .fc-n{top:0;left:44px}
  .flow-circles b{font-size:1rem;text-align:left;flex:1;line-height:1.4}
  .flow-circles li:not(:last-child)::after{display:block;top:62px;left:30px;right:auto;width:2px;height:calc(100% - 50px);background:var(--green-soft)}
}

/* 作業事例 Before/After */
.ba-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem;margin-top:1rem}
.ba{background:var(--bg-card);border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:0 2px 10px rgba(31,42,36,.06)}
.ba-imgs{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--line)}
.ba-col{position:relative}
.ba-col img{width:100%;height:150px;object-fit:cover;display:block}
.ba-tag{position:absolute;top:.5rem;left:.5rem;font-size:.68rem;font-weight:700;color:#fff;padding:.12rem .5rem;border-radius:4px;letter-spacing:.06em}
.ba-tag.before{background:var(--ink-sub)}
.ba-tag.after{background:var(--green)}
.ba figcaption{padding:.85rem 1rem;font-size:.92rem;font-weight:600;color:var(--green-deep);text-align:center}

/* 作業の様子ギャラリー */
.work-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1rem;margin-top:1rem}
.work-gallery figure{margin:0;background:var(--bg-card);border:1px solid var(--line);border-radius:10px;overflow:hidden;box-shadow:0 1px 4px rgba(31,42,36,.06)}
.work-gallery img{width:100%;height:160px;object-fit:cover;display:block}
.work-gallery figcaption{padding:.6rem .8rem;font-size:.85rem;color:var(--green-deep);text-align:center;font-weight:500}
@media(max-width:520px){.work-gallery{grid-template-columns:1fr 1fr;gap:.7rem}.work-gallery img{height:120px}.work-gallery figcaption{font-size:.78rem;padding:.5rem .4rem}}

/* お客様の声 アバター */
.vavatar{width:48px;height:48px;border-radius:50%;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;margin-bottom:.7rem}
.vavatar img{width:30px;height:30px;object-fit:contain}

/* 会社案内・代表挨拶 */
.greet-sec .sec-mini .en{font-size:.72rem;letter-spacing:.25em;color:var(--green-soft);text-transform:uppercase}
.greet-sec .greet-h{font-size:1.5rem;color:var(--green-deep);margin:.2rem 0 .8rem;line-height:1.5}
@media(max-width:480px){
  .greet-sec .greet-h{font-size:1.2rem;letter-spacing:.02em}
  .sec-head h2{font-size:1.28rem;letter-spacing:.02em}
}
.greeting img{height:300px}
@media(max-width:680px){.greeting img{height:240px}}

/* LINEアイコン画像 */
.linebox .lb-icon{background:transparent;width:54px;height:54px}
.linebox .lb-icon img{width:54px;height:54px;object-fit:contain}

/* ===== 色のメリハリ強化（誠実トーン維持・派手にしない／2026-06-24） ===== */
:root{--tint-green:#e8efe9;--tint-teal:#e3edec}
/* セクション背景のリズム（生成り→薄緑→白を交互に・単調回避） */
.sec-tint-green{background:var(--tint-green)}
.sec-tint-teal{background:var(--tint-teal)}

/* サービスカード：白の連続をやめ、上ライン＋アイコン円を3色ローテ */
.svc{border-top:3px solid var(--green);transition:transform .2s,box-shadow .2s}
.svc:hover{transform:translateY(-2px);box-shadow:0 4px 14px rgba(31,42,36,.09)}
.svc-ico{width:56px;height:56px;padding:11px;border-radius:50%;background:var(--accent-bg);object-fit:contain;display:block;margin-bottom:.8rem}
.svc-grid .svc:nth-child(3n+1){border-top-color:var(--green-deep)}
.svc-grid .svc:nth-child(3n+1) .svc-ico{background:#e1ebe4}
.svc-grid .svc:nth-child(3n+2){border-top-color:var(--accent)}
.svc-grid .svc:nth-child(3n+2) .svc-ico{background:#f1e7cf}
.svc-grid .svc:nth-child(3n+3){border-top-color:var(--green-soft)}
.svc-grid .svc:nth-child(3n+3) .svc-ico{background:#e1ecec}

/* 料金の数字はくすみ金で締める（役割色） */
.price-table td.amt{color:var(--accent)}

/* 役割で色分け：確認が必要なこと＝くすみ金の注意カード（緑＝できることと差別化） */
.note-cards .worry{background:#f4f1e8;border:1px solid #e6dec9;border-left:4px solid var(--accent)}
.note-cards .worry p,.note-cards .worry{color:var(--ink-soft)}
/* 費用カード＝金の役割色（上ライン） */
.fee-cards .reason{border-top:3px solid var(--accent);text-align:left}
.fee-cards .reason h3{color:var(--green-deep)}

/* スマホの料金表はカード型に（見やすさ＝費用不安の業種で重要） */
@media(max-width:540px){
  .price-table,.price-table tbody,.price-table tr,.price-table td{display:block;width:100%}
  .price-table thead{display:none}
  .price-table tr{background:var(--bg-card);border-bottom:1px solid var(--line);padding:.7rem .9rem}
  .price-table tr:last-child{border-bottom:none}
  .price-table td{display:flex;justify-content:space-between;gap:1rem;padding:.3rem 0;border-bottom:none;text-align:left}
  .price-table td::before{content:attr(data-label);color:var(--ink-sub);font-size:.82rem;font-weight:500}
  .price-table td.amt{text-align:right;font-weight:700}
}
