/* =========================================================
   サキモトシャリョウ  共通スタイル
   配色: 信頼のグリーン + ゴールドのアクセント / クリームベース
   ========================================================= */

:root{
  --navy:#1c7a37;
  --navy-d:#12591f;
  --accent:#2f9e46;
  --accent-d:#22813a;
  --red:#d23a2e;
  --red-d:#b22a20;
  --ink:#26302a;
  --gray:#5f6b62;
  --line:#e7e7dd;
  --bg:#ffffff;
  --bg-soft:#f5efdd;
  --radius:14px;
  --maxw:1080px;
  --shadow:0 6px 24px rgba(20,40,60,.08);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip}
body{
  margin:0;overflow-x:clip;
  font-family:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.8;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.nb{display:inline-block}
.pc-br{display:inline}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* ---------- ヘッダー ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(8px);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;line-height:1.1}
.brand .logo-mark{
  width:38px;height:38px;border-radius:9px;flex-shrink:0;
  background:linear-gradient(135deg,var(--navy),var(--navy-d));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:800;font-family:Georgia,serif;font-size:18px;
}
.brand .brand-text{display:flex;flex-direction:column}
.brand .brand-jp{font-weight:800;font-size:1.02rem;letter-spacing:.04em;color:var(--navy)}
.brand .brand-en{font-size:.6rem;letter-spacing:.18em;color:var(--gray);text-transform:uppercase}

.nav{display:flex;align-items:center;gap:26px}
.nav a{font-size:.92rem;font-weight:500;color:var(--ink);transition:color .15s}
.nav a:hover,.nav a.is-active{color:var(--accent)}
.nav .nav-cta{
  background:var(--accent);color:#fff;padding:9px 16px;border-radius:999px;
  font-weight:700;font-size:.85rem;
}
.nav .nav-cta:hover{background:var(--accent-d);color:#fff}

.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);margin:5px 0;transition:.2s}

/* ---------- ボタン ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 26px;border-radius:999px;font-weight:700;font-size:.98rem;
  line-height:1.2;white-space:nowrap;transition:transform .12s,background .15s,box-shadow .15s;
  border:2px solid transparent;cursor:pointer;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 6px 16px rgba(28,122,55,.28)}
.btn-primary:hover{background:var(--accent-d);color:#fff}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-d);color:#fff}
.btn-ghost{background:#fff;color:var(--navy);border-color:var(--navy)}
.btn-ghost:hover{background:var(--navy);color:#fff}
/* Instagram用ボタン（インスタ風グラデ） */
.btn-ig{background:linear-gradient(135deg,#f58529,#dd2a7b,#8134af);color:#fff;border-color:transparent;box-shadow:0 6px 16px rgba(221,42,123,.30)}
.btn-ig:hover{color:#fff;filter:brightness(1.06);box-shadow:0 9px 22px rgba(221,42,123,.42)}
.btn .ic{width:20px;height:20px;flex-shrink:0}

/* ---------- セクション共通 ---------- */
section{padding:clamp(42px,7vw,72px) 0}
.section-head{text-align:center;margin-bottom:42px}
.section-head .ey{
  display:inline-block;font-size:.72rem;letter-spacing:.22em;font-weight:700;
  color:var(--accent);text-transform:uppercase;margin-bottom:10px;
}
.section-head h2{font-size:clamp(1.3rem,4.6vw,1.75rem);margin:0;color:var(--navy);letter-spacing:.02em;text-wrap:balance}
.section-head p{color:var(--gray);margin:14px auto 0;max-width:640px;font-size:.98rem;text-wrap:balance}
.bg-soft{background:var(--bg-soft)}

/* ---------- ヒーロー ---------- */
.hero{
  position:relative;color:#fff;overflow:hidden;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-d) 70%);
}
.hero::after{
  content:"";position:absolute;right:-120px;top:-80px;width:420px;height:420px;
  background:radial-gradient(circle,rgba(47,158,70,.32),transparent 70%);
}

/* ===== ヒーロー写真スライドショー（背面固定＋暗フィルター・indexのみ） ===== */
.hero-bg{position:fixed;inset:0;z-index:-1;overflow:hidden;background:#0c1a0f}
.hero-bg .hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.4s ease}
.hero-bg .hero-slide.is-active{opacity:1}
.hero-bg .hero-slide::after{content:"";position:absolute;inset:0;background-image:var(--img);background-size:cover;background-position:center;background-repeat:no-repeat}
.hero-bg .hero-bg-mask{position:absolute;inset:0;background:rgba(0,0,0,.5)}
/* スマホは縦写真1枚（横スライドは隠す） */
@media(max-width:840px){
  .hero-bg{background-image:url('heroM.webp');background-size:cover;background-position:center}
  .hero-bg .hero-slide{display:none}
}
/* indexだけ: bodyを透過して背面の写真を見せ、ヒーロー以下はラッパーで覆う */
html.hero-photo{background:#fff}
html.hero-photo body{background:transparent}
html.hero-photo .hero{background:transparent}
html.hero-photo .hero::after{display:none}
.below-hero{position:relative;z-index:1;background:#fff}
/* 写真の上で読みやすく */
html.hero-photo .hero h1,html.hero-photo .hero p.lead,html.hero-photo .hero .ey{text-shadow:0 2px 14px rgba(0,0,0,.5)}
@media (prefers-reduced-motion: reduce){
  .hero-bg .hero-slide{transition:none}
}
.hero-inner{position:relative;z-index:1;padding:52px 0 56px;max-width:760px}
.hero .ey{
  display:inline-block;font-size:.74rem;letter-spacing:.2em;font-weight:700;
  color:#d6efd6;margin-bottom:18px;
}
.hero h1{font-size:clamp(1.55rem,6.2vw,2.5rem);line-height:1.45;margin:0 0 20px;letter-spacing:.02em}
.hero h1 .hl{color:#ffe08a}
.hero p.lead{font-size:clamp(.95rem,2.7vw,1.05rem);color:#e7f1e6;margin:0 0 34px;max-width:none;text-wrap:pretty}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.hero-badges span{
  font-size:.78rem;font-weight:600;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);padding:6px 13px;border-radius:999px;
}

/* ---------- サービス・カード ---------- */
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 24px;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s;
}
.card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(20,40,60,.12)}
.card .card-ic{
  width:48px;height:48px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  background:rgba(239,125,34,.12);color:var(--accent);margin-bottom:16px;
}
.card .card-ic svg{width:26px;height:26px}
.card h3{margin:0 0 10px;font-size:1.1rem;color:var(--navy);display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:50px}
.card p{margin:0;color:var(--gray);font-size:.92rem}
.card .num{font-family:Georgia,serif;font-size:1.4rem;color:var(--accent);font-weight:700;display:block;margin-bottom:8px}

/* サービス一覧（チップ） */
.service-list{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:8px;padding:0}
.service-list li{
  list-style:none;background:#fff;border:1px solid var(--line);border-radius:999px;
  padding:11px 20px;font-weight:600;font-size:.95rem;color:var(--navy);
  display:flex;align-items:center;gap:9px;box-shadow:0 2px 8px rgba(20,40,60,.05);
}
.service-list li svg{width:19px;height:19px;color:var(--accent);flex-shrink:0}

/* サービス詳細ブロック */
.svc-block{
  display:flex;gap:22px;align-items:flex-start;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:26px 26px;box-shadow:var(--shadow);margin:0 auto 18px;max-width:860px;
}
.svc-block .svc-ic{
  width:54px;height:54px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  background:var(--navy);color:#fff;
}
.svc-block .svc-ic svg{width:28px;height:28px}
.svc-block h3{margin:0 0 6px;font-size:1.2rem;color:var(--navy)}
.svc-block p{margin:0;color:var(--gray);font-size:.95rem}
.svc-block .tag{display:inline-block;margin-top:10px;font-size:.74rem;font-weight:700;color:var(--accent);background:rgba(239,125,34,.1);padding:4px 11px;border-radius:999px}

/* ---------- Instagram ---------- */
.ig-wrap{max-width:760px;margin:0 auto;text-align:center}
.ig-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:8px 0 26px}
.ig-tile{
  position:relative;aspect-ratio:1/1;border-radius:12px;overflow:hidden;
  background:linear-gradient(135deg,#dfe6ee,#eef2f6);display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);
}
.ig-tile svg{width:30px;height:30px;color:#9fb0c0}
.ig-tile span{position:absolute;bottom:8px;left:8px;font-size:.62rem;color:#7d8c9b;font-weight:600}
.ig-note{font-size:.82rem;color:var(--gray);margin-top:6px}

/* ---------- アクセス / 情報テーブル ---------- */
.spec{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.spec th,.spec td{padding:15px 18px;text-align:left;vertical-align:top;border-top:1px solid var(--line);font-size:.95rem}
.spec tr:first-child th,.spec tr:first-child td{border-top:none}
.spec th{width:34%;background:var(--bg-soft);color:var(--navy);font-weight:700;white-space:nowrap}
.spec td{color:var(--gray)}
.map-frame{width:100%;height:340px;border:0;border-radius:var(--radius);margin-top:22px}

/* ---------- CTA バンド ---------- */
.cta-band{background:linear-gradient(135deg,var(--accent),var(--accent-d));color:#fff;text-align:center;padding:clamp(48px,7vw,74px) 0 clamp(64px,9.5vw,100px)}
.cta-band h2{font-size:clamp(1.35rem,4.4vw,1.7rem);margin:0 0 12px}
.cta-band p{margin:0 0 26px;color:#eef7ef;font-size:1rem;text-wrap:balance}
.cta-band .hero-actions{justify-content:center}
.cta-band .btn-ghost{background:#fff;color:var(--navy);border-color:#fff}
.cta-band .btn-ghost:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.cta-band .btn-navy{background:var(--navy)}

/* ---------- パンくず ---------- */
.crumb{font-size:.78rem;color:var(--gray);padding:16px 0}
.crumb a:hover{color:var(--accent)}
.crumb span{color:var(--accent)}

/* ページ見出し（下層） */
.page-hero{background:var(--navy);color:#fff;padding:60px 0 56px;text-align:center}
.page-hero .ey{font-size:.72rem;letter-spacing:.22em;color:#d6efd6;font-weight:700}
.page-hero h1{font-size:clamp(1.45rem,5.2vw,2rem);margin:10px 0 0}

/* FAQ */
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px 22px;margin-bottom:14px;box-shadow:0 2px 8px rgba(20,40,60,.05)}
.faq-item h3{margin:0 0 8px;font-size:1.02rem;color:var(--navy);display:flex;gap:10px}
.faq-item h3::before{content:"Q";color:var(--red);font-weight:800;font-family:Georgia,serif}
.faq-item p{margin:0;color:var(--gray);font-size:.94rem}

/* 連絡カード */
.contact-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;
  box-shadow:var(--shadow);text-align:center;
  display:flex;flex-direction:column;
}
/* 3枚のボタンを同じ幅・高さに、カード下端で揃える */
.contact-card .btn,.contact-card .phone-cta{width:100%;box-sizing:border-box;justify-content:center;min-height:60px;margin:auto 0 0}
.contact-card .phone-cta{padding:8px 18px}
.contact-card .phone-cta .phone-fab-ic{width:40px;height:40px}
.contact-card .c-ic{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.contact-card.ig .c-ic{background:linear-gradient(135deg,#f58529,#dd2a7b,#8134af)}
.contact-card.tel .c-ic{background:var(--navy)}
.contact-card .c-ic svg{width:30px;height:30px;color:#fff}
.contact-card h3{margin:0 0 6px;color:var(--navy);font-size:1.15rem}
.contact-card p{margin:0 0 18px;color:var(--gray);font-size:.9rem}

/* ---------- フッター ---------- */
.site-footer{background:var(--navy-d);color:#cdd9e4;padding:54px 0 26px;font-size:.9rem}
.footer-top{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-bottom:28px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand .brand-jp{color:#fff;font-weight:800;font-size:1.1rem}
.footer-brand .brand-en{color:#8ba3b8;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase}
.footer-brand p{margin:12px 0 0;max-width:300px;color:#9fb3c4;font-size:.85rem}
.footer-nav{display:flex;gap:40px;flex-wrap:wrap}
.footer-nav h4{color:#fff;font-size:.8rem;letter-spacing:.1em;margin:0 0 12px}
.footer-nav ul{list-style:none;margin:0;padding:0}
.footer-nav li{margin-bottom:9px}
.footer-nav a:hover{color:var(--accent)}
.footer-social{display:flex;gap:12px;margin-top:14px}
.footer-social a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:.15s}
.footer-social a:hover{background:var(--accent)}
.footer-social svg{width:20px;height:20px;color:#fff}
.footer-bottom{padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:#7e93a6;font-size:.78rem}

/* ---------- スマホ追従CTA ---------- */
.mobile-cta{display:none}

/* =========================================================
   レスポンシブ
   ========================================================= */
@media(max-width:1024px){
  .grid-3{grid-template-columns:1fr}
}
@media(max-width:840px){
  body{padding-bottom:calc(64px + env(safe-area-inset-bottom))}  /* 追従CTA分の余白 */
  .hero-inner{padding:46px 22px 42px;text-align:center}
  .hero-badges{display:grid;grid-template-columns:repeat(2,auto);justify-content:center;justify-items:center;gap:10px}

  /* ヒーロー/CTAのボタンは縦並び＆全幅で折り返さない */
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{width:100%}

  /* ナビをトグル化 */
  .nav-toggle{display:block}
  .nav{
    position:absolute;top:64px;left:0;right:0;flex-direction:column;gap:0;
    background:#fff;border-bottom:1px solid var(--line);
    max-height:0;overflow:hidden;visibility:hidden;transition:max-height .25s ease,visibility .25s;
  }
  .nav.open{max-height:360px;visibility:visible}
  .nav a{width:100%;padding:15px 22px;border-top:1px solid var(--line)}
  .nav .nav-cta{margin:14px 22px;width:calc(100% - 44px);justify-content:center}

  /* テーブル縦積み */
  .spec,.spec tbody,.spec tr,.spec th,.spec td{display:block;width:auto}
  .spec tr{border-top:1px solid var(--line);padding:12px 16px}
  .spec tr:first-child{border-top:none}
  .spec th,.spec td{border:none;padding:2px 0;white-space:normal}
  .spec th{font-size:.72rem;letter-spacing:.12em;color:var(--gray);background:none}
  .spec td{font-size:.95rem;padding-bottom:4px}

  .svc-block{gap:16px;padding:22px 20px}
  .footer-top{flex-direction:column;gap:24px}
  .map-frame{height:280px}

  /* 追従CTA表示 */
  .mobile-cta{
    display:flex;position:fixed;left:0;right:0;bottom:0;z-index:200;
    box-shadow:0 -4px 16px rgba(0,0,0,.12);
    padding-bottom:env(safe-area-inset-bottom);
  }
  .mobile-cta a{
    flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
    padding:16px 6px;font-weight:700;font-size:.92rem;color:#fff;
  }
  .mobile-cta .m-tel{background:linear-gradient(135deg,#ef5b34,#d8281c);animation:mtel-pulse 2s ease-in-out infinite}
  .mobile-cta .m-tel svg{width:22px;height:22px;animation:mtel-ring 2.2s ease-in-out infinite;transform-origin:center}
  .mobile-cta .m-ig{background:linear-gradient(135deg,#f58529,#dd2a7b,#8134af)}
  .mobile-cta svg{width:20px;height:20px;flex-shrink:0}
}
@media(max-width:560px){
  .grid-3,.grid-2{grid-template-columns:1fr}
  .ig-grid{grid-template-columns:repeat(3,1fr);gap:8px}
  .container{padding:0 18px}

  .hero-inner{padding:30px 20px 34px;text-align:center}
  .hero .ey{font-size:.66rem;letter-spacing:.1em;margin-bottom:14px}
  .hero h1{line-height:1.55;margin-bottom:16px}
  .hero p.lead{margin-bottom:26px}
  .hero-badges{gap:8px;margin-top:22px;justify-content:center;justify-items:center}
  .hero-badges span{font-size:.72rem;padding:5px 11px}

  .section-head{margin-bottom:30px}
  .section-head p{font-size:.92rem}
  .page-hero{padding:46px 0 42px}

  .contact-card .btn{width:100%}
  .btn{padding:14px 20px;font-size:.95rem}

  .service-list{justify-content:center;gap:9px}
  .service-list li{padding:10px 15px;font-size:.9rem}

  .svc-block .svc-ic{width:46px;height:46px}
  .card{padding:22px 20px}
  .ig-note{font-size:.76rem}
}
@media(max-width:380px){
  .brand .brand-jp{font-size:.94rem}
  .brand .logo-mark{width:34px;height:34px;font-size:16px}
}

/* ===== スクロール演出（reveal） ===== */
.has-reveal .reveal{opacity:0;transform:translateY(30px);transition:opacity .75s cubic-bezier(.2,.7,.2,1),transform .75s cubic-bezier(.2,.7,.2,1);will-change:opacity,transform}
.has-reveal .reveal.is-visible{opacity:1;transform:none} 
.has-reveal .reveal.rev-zoom{transform:scale(.9)}
.has-reveal .reveal.rev-down{transform:translateY(-30px)}
.has-reveal .reveal.rev-l{transform:translateX(-44px)}
.has-reveal .reveal.rev-r{transform:translateX(44px)}
.has-reveal .rescue-grid .reveal:nth-child(2){transition-delay:.1s}
.has-reveal .rescue-grid .reveal:nth-child(3){transition-delay:.2s}
.has-reveal .rescue-grid .reveal:nth-child(4){transition-delay:.3s}
.has-reveal .rescue-grid .reveal:nth-child(5){transition-delay:.4s}
.has-reveal .rd1{transition-delay:.06s}
.has-reveal .rd2{transition-delay:.16s}
.has-reveal .rd3{transition-delay:.26s}
.has-reveal .rd4{transition-delay:.36s}
.has-reveal .grid .reveal:nth-child(2){transition-delay:.12s}
.has-reveal .grid .reveal:nth-child(3){transition-delay:.24s}
.has-reveal .grid .reveal:nth-child(4){transition-delay:.36s}
@media (prefers-reduced-motion: reduce){
  .has-reveal .reveal{opacity:1!important;transform:none!important;transition:none!important}
}


/* ===== Instagram フィード（Behold 自動更新） ===== */
.ig-feed{margin:8px auto 26px;max-width:900px;min-height:200px}

/* ===== ページ遷移ローディング（積載車が走り抜ける） ===== */
#page-loader{position:fixed;inset:0;z-index:10000;background:rgba(255,255,255,.93);display:flex;align-items:center;justify-content:center;overflow:hidden;opacity:0;visibility:hidden;transition:opacity .17s ease}
#page-loader.show,html.pl-arriving #page-loader{opacity:1;visibility:visible}
.pl-logo{width:min(62vw,420px);height:auto;opacity:.13;pointer-events:none;user-select:none}
.pl-truck{position:absolute;top:50%;left:0;width:min(52vw,360px);height:auto;filter:drop-shadow(0 8px 14px rgba(20,40,60,.13));will-change:transform;transform:translate(128vw,-50%)}
#page-loader.run .pl-truck{animation:truck-run 1.25s cubic-bezier(.42,.03,.58,1) forwards}
@keyframes truck-run{
  0%{transform:translate(128vw,-50%)}
  18%{transform:translate(66vw,calc(-50% - 5px))}
  34%{transform:translate(24vw,-50%)}
  50%{transform:translate(-12vw,calc(-50% - 5px))}
  66%{transform:translate(-46vw,-50%)}
  100%{transform:translate(-134vw,calc(-50% - 2px))}
}
@media(prefers-reduced-motion:reduce){
  .pl-truck{transform:translate(0,-50%)}
  #page-loader.run .pl-truck{animation:none!important}
}
/* スマホは積載車を速く走らせて遷移をキビキビに */
@media(max-width:840px){
  #page-loader.run .pl-truck{animation-duration:.82s}
}


.brandcard{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow);max-width:520px;margin:0 auto}
.brandcard svg{width:100%;height:auto;display:block}

/* ===== 名刺アイコン配置 ===== */
.brand-logo{height:36px;width:auto;display:block}
.card .card-icon{width:72px;height:auto;flex-shrink:0;margin:0}
.rescue-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:820px;margin:0 auto}
@media(max-width:680px){.rescue-grid{grid-template-columns:repeat(2,1fr)}}
.rescue-item{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px 12px 13px;box-shadow:var(--shadow);text-align:center;display:flex;flex-direction:column;align-items:center}
.rescue-item img{width:100%;height:120px;object-fit:contain;display:block;margin:0 0 9px}
.rescue-item span{display:block;font-weight:700;color:var(--navy);font-size:.92rem}
@media(max-width:560px){
  .brand-logo{height:30px}
  .rescue-grid{grid-template-columns:repeat(2,1fr)}
  .rescue-item img{height:104px}
}

/* ===== 代車積載レスキューの流れ（ワークフロー） ===== */
.flow-grid{list-style:none;margin:28px auto 0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:980px}
.flow-step{position:relative;background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px 16px 18px;box-shadow:var(--shadow);text-align:center;display:flex;flex-direction:column;align-items:center}
.flow-num{position:absolute;top:-14px;left:50%;transform:translateX(-50%);width:32px;height:32px;border-radius:50%;background:var(--navy);color:#fff;font-weight:800;font-size:.98rem;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 8px rgba(20,40,60,.2)}
.flow-img{width:100%;margin:6px 0 12px}
.flow-img img{width:100%;height:150px;object-fit:contain;display:block}
.flow-step h3{margin:0 0 8px;font-size:1.02rem;color:var(--navy)}
.flow-step p{margin:0;font-size:.86rem;color:var(--gray);line-height:1.75}
/* 連結の矢印（PCのみ） */
@media(min-width:861px){
  .flow-step:not(:last-child)::after{content:"";position:absolute;top:50%;right:-15px;width:13px;height:13px;border-top:3px solid #cdc8b6;border-right:3px solid #cdc8b6;transform:translateY(-50%) rotate(45deg);z-index:1}
}
@media(max-width:860px){
  .flow-grid{grid-template-columns:repeat(2,1fr);gap:30px 18px}
}
@media(max-width:430px){
  .flow-grid{grid-template-columns:1fr;max-width:340px;gap:34px}
  .flow-img img{height:160px}
}
/* フロー4枚: 下から順番に滑り上がって浮き上がる */
.has-reveal .flow-step.rev-rise{opacity:0;transform:translateY(90px) scale(.95);transition:none;will-change:transform,opacity}
.has-reveal .flow-step.rev-rise.is-visible{animation:flow-rise .9s cubic-bezier(.2,.72,.24,1) both}
.has-reveal .flow-grid .flow-step.rev-rise:nth-child(1).is-visible{animation-delay:.05s}
.has-reveal .flow-grid .flow-step.rev-rise:nth-child(2).is-visible{animation-delay:.19s}
.has-reveal .flow-grid .flow-step.rev-rise:nth-child(3).is-visible{animation-delay:.33s}
.has-reveal .flow-grid .flow-step.rev-rise:nth-child(4).is-visible{animation-delay:.47s}
@keyframes flow-rise{
  0%   {opacity:0;transform:translateY(90px) scale(.95)}
  55%  {opacity:1;transform:translateY(-12px) scale(1.015)}
  76%  {transform:translateY(4px) scale(.998)}
  100% {opacity:1;transform:translateY(0) scale(1)}
}
@media (prefers-reduced-motion: reduce){
  .has-reveal .flow-step.rev-rise,
  .has-reveal .flow-step.rev-rise.is-visible{opacity:1!important;transform:none!important;animation:none!important}
}

/* Instagramセクション幅（カラム配置はBeholdウィジェット側で制御） */
.ig-section{max-width:1100px}

/* 電話番号テキスト表示（ボタンは廃止） */
.phone-num{font-weight:800;font-size:1.3rem;color:var(--navy);letter-spacing:.02em;margin:0}
.rescue-tel{font-weight:700;color:var(--navy);font-size:1.05rem;margin:0}
.rescue-tel strong{font-size:1.25rem;letter-spacing:.02em}
/* スマホ追従CTAはInstagramのみ（電話ボタン廃止） */
.mobile-cta .m-ig{flex:1}

/* フッター: ブランド名の右にInstagram */
.footer-brand .fb-head{display:flex;align-items:center;gap:16px;margin-bottom:4px}
.footer-brand .fb-head .footer-social{margin-top:0}

/* ごあいさつ本文: 文節で改行・バランス */
.greeting p{word-break:auto-phrase;text-wrap:pretty;line-height:1.95}

/* レスキュー: 緊急→電話CTAへ誘導 */
.rescue-cta{max-width:460px;margin:30px auto 0;text-align:center;background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px 22px;box-shadow:var(--shadow)}

/* 24hバッジ: 画面外から転がってきてガコッとはまる */
.rescue-sec{overflow-x:clip}
.has-reveal img.rescue-badge.rev-roll{opacity:0;transform:none;transition:none;will-change:transform}
.has-reveal img.rescue-badge.rev-roll.is-visible{opacity:1;animation:rescue-roll 1.3s cubic-bezier(.2,.7,.2,1) .12s both}
@keyframes rescue-roll{
  0%   {opacity:0;transform:translateX(calc(-50vw - 120%)) rotate(-900deg)}
  8%   {opacity:1}
  52%  {transform:translateX(7%) rotate(24deg)}
  66%  {transform:translateX(-3%) translateY(-2%) rotate(-8deg)}
  78%  {transform:translateX(2%) translateY(1.2%) rotate(4deg)}
  88%  {transform:translateX(-0.8%) rotate(-1.6deg)}
  100% {transform:translateX(0) translateY(0) rotate(0)}
}
@media (prefers-reduced-motion: reduce){
  .has-reveal img.rescue-badge.rev-roll,
  .has-reveal img.rescue-badge.rev-roll.is-visible{opacity:1!important;transform:none!important;animation:none!important}
}
.rescue-cta-ic{width:62px;height:62px;object-fit:contain;display:block;margin:0 auto 10px}
.rescue-cta-lead{font-weight:700;color:var(--navy);margin:0 0 6px;font-size:1.02rem}
.rescue-cta-note{margin:0 0 18px;font-size:.86rem;color:var(--gray);font-weight:600;line-height:1.6}

/* ===== レスポンシブ・バランス（改行安定化） 全ページ共通 ===== */
h1,h2,h3{text-wrap:balance}
p,li,figcaption,.ig-note,.rescue-item span,.card p,.svc-block p,.faq-item p,.contact-card p,.section-head p,.hero p.lead{text-wrap:pretty;line-break:strict;word-break:auto-phrase}

/* 表示完了時は必ず元位置へ（バリエーション指定の打ち消し対策） */
.has-reveal .reveal.rev-l.is-visible,.has-reveal .reveal.rev-r.is-visible,.has-reveal .reveal.rev-zoom.is-visible,.has-reveal .reveal.rev-down.is-visible{transform:none}

/* フッターの店名をロゴ画像に */
.footer-logo{height:30px;width:auto;display:block;margin-bottom:6px}

/* 見出し内のサキモトシャリョウをロゴ画像に */
.h2-logo{display:inline-block;height:1.15em;width:auto;vertical-align:-0.22em;margin-right:.12em}

/* レスキュー: 24時間対応バナー */
.rescue-badge{width:100%;max-width:240px;height:auto;display:block;margin:0 auto 12px}

/* ===== お客様の声 / Google口コミ ===== */
.rv-summary{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:14px;flex-wrap:wrap}
.rv-summary .rv-score{font-size:2rem;font-weight:800;color:var(--navy);line-height:1}
.rv-summary .rv-stars-top{color:#f4b400;font-size:1.3rem;letter-spacing:3px}
.rv-summary .rv-count{display:inline-flex;align-items:center;gap:6px;font-size:.9rem;color:var(--gray);font-weight:600}
.rv-summary .g-ic{flex-shrink:0}
.reviews-grid{column-count:2;column-gap:22px;max-width:860px;margin:30px auto 0}
.rv-card{break-inside:avoid;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;margin-bottom:22px;box-shadow:0 4px 16px rgba(20,40,30,.06)}
.rv-head{display:flex;align-items:center;gap:12px}
.rv-avatar{width:42px;height:42px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.05rem}
.rv-meta{display:flex;flex-direction:column;line-height:1.3;flex:1;min-width:0}
.rv-name{font-weight:700;color:var(--ink);font-size:.97rem}
.rv-date{font-size:.78rem;color:#9aa39a}
.rv-g{flex-shrink:0;display:flex}
.rv-stars{margin:11px 0 9px;letter-spacing:2px;font-size:1.02rem;color:#dcdcd2}
.rv-stars .on{color:#f4b400}
.rv-text{margin:0;font-size:.92rem;line-height:1.85;color:#444}
@media (max-width:640px){
  .reviews-grid{column-count:1;max-width:460px}
}

/* セクション区切り（line—◆—line） */
.sec-divide{max-width:560px;margin:-18px auto;padding:0 22px;display:flex;align-items:center;gap:16px}
.sec-divide::before,.sec-divide::after{content:"";flex:1;height:1px;background:var(--line)}
.sec-divide .dot{width:8px;height:8px;background:var(--accent);transform:rotate(45deg);border-radius:2px;flex-shrink:0;opacity:.7}

/* ===== 電話CTA（オレンジのピル）: 右下追従(.phone-fab) と RESCUE内(.phone-cta) で共通デザイン ===== */
.phone-fab,.phone-cta{
  display:inline-flex;align-items:center;gap:12px;
  padding:12px 22px 12px 14px;border-radius:999px;
  background:linear-gradient(135deg,#f7991f,#ef6a1e);
  color:#fff;text-decoration:none;
  box-shadow:0 12px 28px rgba(220,90,20,.42);
}
.phone-fab:hover,.phone-cta:hover{color:#fff;box-shadow:0 16px 34px rgba(220,90,20,.5);filter:brightness(1.05)}
.phone-fab{position:fixed;right:24px;bottom:24px;z-index:180;transform-origin:bottom right;transition:box-shadow .2s,filter .2s;will-change:transform,opacity}
.phone-cta{margin-top:4px}
.phone-fab-ic{position:relative;width:42px;height:42px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.22);border-radius:50%}
.phone-fab-ic svg{width:22px;height:22px;animation:fab-wiggle 3s ease-in-out infinite}
/* 着信リングのパルス（常時さりげなく注目を集める） */
.phone-fab-ic::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid rgba(255,255,255,.7);animation:fab-ring 2.1s ease-out infinite}
.phone-fab-txt{display:flex;flex-direction:column;line-height:1.2}
.phone-fab-txt small{font-size:.7rem;font-weight:600;opacity:.95;letter-spacing:.01em}
.phone-fab-txt b{font-size:1.2rem;font-weight:800;letter-spacing:.02em}

@keyframes fab-ring{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.85);opacity:0}}
@keyframes fab-wiggle{0%,84%,100%{transform:rotate(0)}88%{transform:rotate(-13deg)}92%{transform:rotate(11deg)}96%{transform:rotate(-5deg)}}

/* 収納＝隅へビュンッと吸い込まれる（ウィンドウup→fling）／復帰＝ボヨンッと跳ね戻る */
@keyframes fab-leave{
  0%{transform:translate(0,0) rotate(0) scale(1);opacity:1}
  24%{transform:translate(-8px,-12px) rotate(-5deg) scale(1.08);opacity:1}
  100%{transform:translate(46px,78px) rotate(26deg) scale(.28);opacity:0}
}
@keyframes fab-enter{
  0%{transform:translate(46px,78px) rotate(26deg) scale(.28);opacity:0}
  62%{transform:translate(-7px,-7px) rotate(-4deg) scale(1.07);opacity:1}
  82%{transform:translate(3px,3px) rotate(2deg) scale(.98);opacity:1}
  100%{transform:translate(0,0) rotate(0) scale(1);opacity:1}
}
.phone-fab.is-leaving{animation:fab-leave .52s cubic-bezier(.5,.04,.72,.55) forwards;pointer-events:none}
.phone-fab.is-entering{animation:fab-enter .6s cubic-bezier(.22,.68,.3,1) forwards}

/* RESCUE内ボタン: 右下FABが消えた瞬間にポンッと出現（はめ込み演出） */
.phone-cta.armed{opacity:0}
@keyframes pill-pop{
  0%{transform:scale(.2) translateY(14px);opacity:0}
  55%{transform:scale(1.14) translateY(0);opacity:1}
  78%{transform:scale(.95)}
  100%{transform:scale(1);opacity:1}
}
.phone-cta.pop{animation:pill-pop .52s cubic-bezier(.2,.7,.3,1) .2s backwards}

/* スマホ下部バー「電話する」: 脈打つ＋電話アイコンがリンリン鳴る */
@keyframes mtel-pulse{0%,100%{filter:brightness(1)}50%{filter:brightness(1.16)}}
@keyframes mtel-ring{
  0%,62%,100%{transform:rotate(0) scale(1)}
  70%{transform:rotate(-15deg) scale(1.14)}
  78%{transform:rotate(13deg) scale(1.14)}
  86%{transform:rotate(-9deg) scale(1.08)}
  94%{transform:rotate(4deg) scale(1.03)}
}

/* スマホには出さない（下部の追従バーがあるため） */
@media(max-width:840px){ .phone-fab{display:none} }
@media (prefers-reduced-motion: reduce){
  .phone-fab-ic svg,.phone-fab-ic::after{animation:none}
  .phone-fab.is-leaving{animation:none;opacity:0;transform:none;pointer-events:none}
  .phone-fab.is-entering{animation:none;opacity:1;transform:none}
  .phone-cta.armed{opacity:1}
  .phone-cta.pop{animation:none}
  .mobile-cta .m-tel,.mobile-cta .m-tel svg{animation:none}
}
