/* ============================
   カナメイシ LP — style.css
   ============================ */

:root{
  --bg:#f6f1e9;
  --bg-card:#ffffff;
  --ink:#2b2b2b;
  --ink-soft:#707070;
  --navy:#2f3a52;
  --navy-deep:#283146;
  --gold:#d98020;
  --gold-soft:#f0aa60;
  --gold-pale:#fde8c8;
  --danger:#b4452f;
  --line:#e4dccc;
  --maxw:480px;
  --font-sans:"Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;
  --font-serif:"Noto Serif JP",serif;
}

/* ---- ユーティリティ ---- */
.text-gold   { color: var(--gold); }
.lead-light  { color: var(--ink-soft); }
.lead-center { text-align: center; }
.em-white    { color: #fff; font-weight: 700; }
.price-tax   { font-size: 13px; }
.stat-unit   { font-size: 18px; }
.badge-wrap  { text-align: center; margin-top: 26px; }

/* .band セクション内の2つ目の見出しに上余白 */
.band-title-2 { margin-top: 38px; }

/* テーブル補助テキスト */
.th-sub   { font-weight: 400; font-size: 10px; }
.td-note  { font-size: 10px; }

/* スクリーンリーダー専用（視覚的に非表示） */
.sr-only  {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* 料金セクション下部の画像ブロック */
.pricing-img { margin-top: 24px; border-radius: 10px; overflow: hidden; }

/* ---- リセット ---- */
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font-sans);
  color:var(--ink);
  background:#d9d2c6;
  line-height:1.7;
  font-size:15px;
  -webkit-font-smoothing:antialiased;
}
.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  background:var(--bg);
  overflow:hidden;
  box-shadow:0 0 40px rgba(0,0,0,.12);
}
img{max-width:100%;display:block;}
.serif{font-family:var(--font-serif);}

/* ---- セクション共通 ---- */
section{padding:54px 24px;}
.sec-title{
  font-family:var(--font-serif);
  font-weight:700;
  font-size:21px;
  line-height:1.6;
  text-align:center;
  color:var(--navy);
  margin-bottom:28px;
}
.sec-title .mark{color:var(--danger);}
.lead{font-size:14px;color:var(--ink-soft);}
.leadnv{font-size:14px;color:var(--bg);}
.em{color:var(--danger);font-weight:700;}
.num{font-family:var(--font-serif);font-weight:900;color:var(--danger);}

/* ============================
   ヘッダー
   ============================ */
.site-head{
  position:sticky;top:0;z-index:50;
  background:rgba(246,241,233,.92);
  -webkit-backdrop-filter:blur(6px);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 18px;
}
.site-head img{height:26px;width:auto;}
.head-cta{
  font-size:11px;font-weight:700;color:#fff;
  background:var(--gold);
  padding:7px 12px;border-radius:30px;text-decoration:none;
  white-space:nowrap;
}

/* ============================
   ヒーロー
   ============================ */
.hero{
  position:relative;
  padding:0;
  color:#fff;
  background:linear-gradient(180deg,rgba(33,30,26,.50),rgba(33,30,26,.75)),
    url("image/hero.webp") center/cover;
}
.hero-inner{padding:52px 24px 40px;}
.hero h1{
  font-family:var(--font-serif);
  font-weight:700;
  font-size:24px;
  line-height:1.95;
  margin-bottom:16px;
}
/* 1行ずつ白背景タグ */
.hero h1 .h1-inner{
  display:inline;
  background:rgba(255,255,255,.95);
  color:var(--navy);
  padding:3px 10px;
  -webkit-box-decoration-break:clone;
  box-decoration-break:clone;
}
.hero h1 .accent{color:var(--gold);}
.hero .strong{font-size:28px;display:inline;}
/* 3つのポイント：円形バッジ */
.hero-bul{display:flex;gap:10px;margin-top:0;justify-content:center;}
.hero-bul div{
  width:100px;height:100px;
  border-radius:50%;
  flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;
  background:rgba(217,128,32,.85);
  border:2px solid rgba(240,170,96,.5);
  font-size:11px;font-weight:700;line-height:1.45;
  text-align:center;
  padding:8px;
}
.hero-bul .ic{font-size:18px;display:block;margin-bottom:4px;}

/* ============================
   画像プレースホルダー
   ============================ */
/* src="" の img 要素をグレーの箱として表示 */
img[src=""]{
  background:#dbd5cc;
  display:block;
}
/* 料金ブロック（ヒーロー下部） */
.price-block{

  color:#fff;
  text-align:center;
  padding:28px 24px 32px;
}
.price-block .cap{font-size:13px;color:#cdd3df;line-height:1.6;}
.price-block .anniv{
  display:inline-block;
  background:var(--gold);
  color:#fff;font-weight:700;font-size:12px;
  padding:3px 16px;border-radius:30px;margin:14px 0 6px;
}
.price-block .big{
  font-family:var(--font-serif);
  font-weight:900;
  line-height:1;
}
.price-block .big b{font-size:64px;color:var(--gold-soft);}
.price-block .big span{font-size:20px;}
.price-block .note{font-size:10.5px;color:#9aa1b2;margin-top:12px;line-height:1.6;}
/* 先着限定バッジ */
.limit-badge{
  position:relative;
  display:inline-flex;
  align-items:stretch;
  border-radius:8px;
  overflow:visible;
  margin-top:16px;
}
/* パルス用リング（transform/opacity のみで GPU コンポジット） */
.limit-badge::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:8px;
  border:2px solid var(--gold);
  opacity:.8;
  transform:scale(1);
  animation:limit-pulse 1.8s ease-out infinite;
  pointer-events:none;
}
@keyframes limit-pulse{
  0%  { transform:scale(1);   opacity:.7; }
  70% { transform:scale(1.18);opacity:0;  }
  100%{ transform:scale(1.18);opacity:0;  }
}
.limit-count{
  background:var(--gold);
  color:#fff;
  font-family:var(--font-serif);
  font-size:17px;
  font-weight:900;
  padding:7px 16px;
  letter-spacing:.04em;
}
.limit-label{
  background:#fff2;
  border:1.5px solid var(--gold-soft);
  border-left:none;
  color:var(--gold-soft);
  font-size:11px;
  font-weight:700;
  padding:7px 14px;
  display:flex;
  align-items:center;
  letter-spacing:.1em;
}

/* ============================
   CTAボタン
   ============================ */
.cta{
  display:block;text-align:center;text-decoration:none;
  background:var(--gold);
  color:var(--bg-card);font-weight:700;font-size:17px;
  font-family:var(--font-serif);
  padding:18px;border-radius:10px;
  box-shadow:0 8px 20px rgba(217,128,32,.4);
  transition:transform .15s,box-shadow .15s;
  letter-spacing:.02em;
}
.cta:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(217,128,32,.5);}
.cta .sub{display:block;font-size:11px;font-weight:500;opacity:.9;margin-bottom:3px;letter-spacing:0;}
.cta-gold{background:var(--gold);box-shadow:0 8px 20px rgba(40,49,70,.35);}
.cta-navy:hover{box-shadow:0 12px 26px rgba(40,49,70,.45);}
.cta-wrap{padding:24px 24px 40px;}

/* ============================
   問題提起セクション
   ============================ */
.sec-problem{background:var(--bg);}
.choices{display:flex;gap:10px;margin:22px 0;}
.choices div{
  flex:1;background:#cfc7b8;color:#6b6457;
  text-align:center;padding:18px 6px;border-radius:8px;
  font-weight:700;font-size:14px;
}
.voice{
  text-align:center;font-family:var(--font-serif);
  font-size:19px;font-weight:600;color:var(--navy);
  margin:18px 0 8px;
}
.voice small{
  display:block;font-size:13px;font-weight:400;
  color:var(--ink-soft);font-family:var(--font-sans);margin-top:8px;
}
.card{
  background:var(--bg-card);
  border-radius:12px;
  padding:22px 20px;
  margin-top:18px;
  box-shadow:0 4px 14px rgba(0,0,0,.05);
  border:1px solid var(--line);
}
.card h3{
  font-family:var(--font-serif);font-size:16px;color:var(--navy);
  margin-bottom:10px;
  display:flex;align-items:center;gap:8px;
}
.card h3::before{
  content:"";width:6px;height:20px;background:var(--gold);
  border-radius:3px;display:inline-block;flex-shrink:0;
}
.stat-box{
  background:var(--gold-pale);
  border-radius:10px;text-align:center;
  padding:16px;margin-top:14px;
}
.stat-box .n{
  font-family:var(--font-serif);font-weight:900;
  font-size:34px;color:var(--danger);line-height:1.1;
}
.stat-box .l{font-size:12px;color:var(--ink-soft);margin-top:4px;}

/* conic-gradient によるドーナツグラフ */
.donut-wrap{text-align:center;margin-top:16px;}
.donut{
  width:150px;height:150px;border-radius:50%;margin:0 auto;
  background:conic-gradient(var(--danger) 0 74.9%,var(--gold) 74.9% 83.4%,#b9b1a2 83.4% 91.5%,#d7d0c2 91.5% 100%);
  position:relative;
}
.donut::after{
  content:"旧耐震\A74.9%";white-space:pre;
  position:absolute;inset:28px;border-radius:50%;background:var(--bg-card);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:var(--font-serif);font-weight:900;color:var(--danger);
  font-size:15px;line-height:1.3;
}
.donut-cap{font-size:11.5px;color:var(--ink-soft);margin-top:10px;}

/* ============================
   危険訴求バンド（濃紺背景）
   ============================ */
.band{background:var(--navy-deep);color:#fff;}
.band .sec-title{color:#fff;}
.band .sec-title .mark{color:var(--gold-soft);}
.band-img{border-radius:10px;overflow:hidden;margin-top:18px;border:1px solid rgba(255,255,255,.12);}
.band-img img{width:100%;height:200px;object-fit:cover;object-position:center;}
.band-fact{text-align:center;margin-top:24px;font-size:15px;line-height:1.9;}
.band-fact .huge{
  font-family:var(--font-serif);font-weight:900;
  font-size:48px;color:var(--gold-soft);display:block;line-height:1.1;margin-top:6px;
}

/* ============================
   解決策（在宅避難メリット）
   ============================ */
.sec-solution{background:var(--bg);}
.merit-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px;}
.merit{
  background:var(--bg-card);border:1px solid var(--line);border-radius:12px;
  overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.05);
}
.merit .mimg{height:100px;overflow:hidden;}
.merit .mimg img{width:100%;height:100%;object-fit:cover;}
.merit p{
  padding:12px 10px;font-size:12.5px;font-weight:700;
  text-align:center;color:var(--navy);line-height:1.5;
}
.badge{
  display:inline-block;background:var(--gold);color:#fff;
  font-size:12px;font-weight:700;padding:5px 18px;border-radius:30px;
  margin:0 auto 4px;
}

/* ============================
   会社紹介 / evoltz 連携
   ============================ */
.sec-company{padding:0;}

.company-head{
  background:var(--gold);
  text-align:center;color:#fff;
  font-family:var(--font-serif);
  font-weight:700;font-size:20px;line-height:1.75;
  padding:48px 28px 52px;
}
.v-arrow{
  width:0;height:0;margin:0 auto;
  border-left:28px solid transparent;
  border-right:28px solid transparent;
  border-top:22px solid var(--gold);
}
.company-body{padding:36px 24px 54px;background:var(--bg);}
.company-body .sec-title{margin-bottom:16px;}

.evoltz-banner{
  background:var(--bg);
  border-radius:12px;
  padding:20px 18px;
  margin-top:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
}
.evoltz-text{
  font-family:var(--font-serif);font-weight:900;
  font-size:28px;color:#fff;letter-spacing:.03em;
  line-height:1;
}
.evoltz-text .ev-l{color:var(--gold-soft);}
.evoltz-x{color:var(--gold-soft);font-size:20px;font-weight:700;}
.kaname-logo-wrap img{height:32px;filter:brightness(0) invert(1);opacity:.9;}

.partner-stats{display:flex;gap:8px;margin-top:12px;}
.pstat{
  flex:1;background:var(--navy-deep);color:#fff;border-radius:10px;
  text-align:center;padding:16px 4px;
}
.pstat .n{
  font-family:var(--font-serif);font-weight:900;
  font-size:26px;color:var(--gold-soft);line-height:1;
}
.pstat .n small{font-size:13px;}
.pstat .l{font-size:10px;margin-top:6px;color:#cdd3df;line-height:1.4;}

/* ============================
   サービス内容
   ============================ */
.sec-services{background:var(--bg);}
.service{
  display:flex;gap:16px;align-items:flex-start;
  padding:22px 0;border-bottom:1px solid var(--line);
}
.service:last-child{border-bottom:none;}
.service .s-img{
  width:100px;height:100px;flex-shrink:0;
  border-radius:10px;overflow:hidden;
}
.service .s-img img{width:100%;height:100%;object-fit:cover;}
.service h4{
  font-family:var(--font-serif);font-size:17px;
  color:var(--gold);margin-bottom:6px;
}
.service p{font-size:12.5px;color:var(--ink-soft);line-height:1.7;}

/* ============================
   フロー（ジグザグ交互レイアウト）
   ============================ */
.sec-flow{background:var(--bg);}
.flow-grid{
  display:flex;flex-direction:column;
  margin-top:28px;
}
.flow-item{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  align-items:center;
  padding:20px 0;
  border-bottom:1px solid var(--line);
}
.flow-item:last-child{border-bottom:none;}
/* .flow-rev：画像を左・テキストを右に反転 */
.flow-item.flow-rev .flow-photo{order:-1;}

.flow-num-label{
  display:flex;align-items:center;gap:10px;margin-bottom:8px;
}
.step-circle{
  width:36px;height:36px;flex-shrink:0;
  border-radius:50%;
  background:var(--bg-card);border:1px solid var(--line);
  color:var(--gold-soft);
  font-family:var(--font-serif);font-weight:900;font-size:13px;
  display:flex;align-items:center;justify-content:center;
}
.flow-item h4{
  font-family:var(--font-serif);font-size:14px;
  color:var(--navy);font-weight:700;
  display:inline;
}
.flow-sub{
  font-size:11px;color:var(--gold);font-weight:700;
  margin:4px 0 6px;font-style:italic;
}
.flow-item .flow-desc{
  font-size:11.5px;color:var(--ink-soft);line-height:1.7;
}
.flow-photo img{
  width:100%;aspect-ratio:4/3;
  object-fit:cover;border-radius:10px;display:block;
}
.flow-diagram{margin-top:28px;}
.flow-diagram img{border-radius:10px;border:1px solid var(--line);}

/* ============================
   料金比較表
   ============================ */
.sec-pricing{background:var(--navy-deep);color:#fff;}
.sec-pricing .sec-title{color:#fff;}
.ptable{
  width:100%;border-collapse:collapse;margin-top:18px;
  background:#fff;border-radius:10px;overflow:hidden;font-size:12px;
  box-shadow:0 8px 24px rgba(0,0,0,.25);
}
.ptable th,.ptable td{padding:11px 6px;text-align:center;border-bottom:1px solid var(--line);}
.ptable thead th{font-size:11px;color:#fff;}
.ptable thead .c-old{background:#6b6457;}
.ptable thead .c-us{background:var(--gold);}
.ptable thead .c-item{background:#fff;}
.ptable tbody th{background:#f4efe6;color:var(--navy);font-weight:700;font-size:11.5px;}
.ptable td.old{color:#8a8378;}
.ptable td.us{
  background:var(--gold-pale);color:var(--danger);
  font-weight:700;font-family:var(--font-serif);
}
.ptable td.us small{font-weight:400;color:var(--ink-soft);}
.pricing-note{font-size:10.5px;color:#9aa1b2;margin-top:12px;line-height:1.6;}

/* ============================
   代表メッセージ（Our Story）
   ============================ */
.sec-story{background:var(--bg);}
.story-layout{
  display:grid;
  grid-template-columns:1fr 94px;
  gap:16px;
  align-items:start;
  margin-top:4px;
}
.story-q{
  font-family:var(--font-serif);font-size:14px;
  color:var(--navy);font-weight:700;line-height:1.7;
  margin-bottom:14px;
  border-left:3px solid var(--gold);
  padding-left:10px;
}
.story-body p{font-size:12.5px;color:var(--ink-soft);margin-bottom:10px;line-height:1.8;}
.sign{
  text-align:right;font-family:var(--font-serif);
  color:var(--navy);margin-top:10px;
}
.sign small{display:block;font-size:11px;color:var(--ink-soft);}
.sign b{font-size:16px;}
.rep-photo{
  width:94px;height:124px;border-radius:8px;flex-shrink:0;
  background:#54607a;
  object-fit:cover;object-position:top center;
}

/* ============================
   クロージングCTA
   ============================ */
.closing{
  text-align:center;
  background:var(--bg);
  padding:64px 24px;
}
.closing h2{
  font-family:var(--font-serif);font-weight:700;
  font-size:26px;line-height:1.75;
  color:var(--navy);
}
.closing p{font-size:14px;margin:14px 0 30px;color:var(--ink-soft);}

/* ============================
   フッター
   ============================ */
footer{
  background:var(--gold);color:var(--ink-soft);
  text-align:center;padding:36px 24px;
}
footer img{height:34px;margin:0 auto 16px;filter:brightness(0) invert(1);opacity:.95;}
footer .fname{font-family:var(--font-serif);font-size:15px;color:#fff;margin-bottom:6px;}
footer .fsmall{font-size:11px;color:var(--bg);line-height:1.8;}

/* ============================
   下部固定CTA（スクロール連動）
   ============================ */
.sticky-cta{
  position:fixed;bottom:0;left:0;right:0;z-index:60;
  max-width:var(--maxw);margin:0 auto;
  padding:10px 16px;
  background:rgba(246,241,233,.95);
  -webkit-backdrop-filter:blur(6px);
  backdrop-filter:blur(6px);
  border-top:1px solid var(--line);
  transform:translateY(120%);
  transition:transform .3s ease;
}
.sticky-cta.show{transform:translateY(0);}
.sticky-cta .cta{padding:14px;font-size:16px;}

/* デスクトップ幅では角丸を付ける */
@media(min-width:481px){
  .sticky-cta{border-radius:14px 14px 0 0;}
}

/* ============================
   アニメーション
   ============================ */

/* スクロール連動フェードイン（JS で .is-visible を付与） */
.fade-up{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .65s ease, transform .65s ease;
  will-change:opacity, transform; /* GPU合成レイヤーに昇格 */
}
.fade-up.is-visible{
  opacity:1;
  transform:translateY(0);
  will-change:auto;
}

/* ヒーロー：ページ読み込み時にテキストをスライドイン */
@keyframes hero-in{
  from{ opacity:0; transform:translateY(-14px); }
  to  { opacity:1; transform:translateY(0); }
}
.hero h1   { animation:hero-in .9s ease .1s both; }
.hero-bul  { animation:hero-in .9s ease .35s both; }
.price-block{ animation:hero-in .9s ease .55s both; }
.cta-wrap  { animation:hero-in .9s ease .75s both; }

/* CTAボタンの脈動 — box-shadow を直接アニメせず ::after の opacity で表現（Paint 回避） */
.cta{ position:relative; overflow:hidden; }
.cta::after{
  content:"";
  position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  box-shadow:0 16px 40px rgba(217,128,32,.65);
  opacity:0;
  animation:pulse-gold 2.8s ease-in-out infinite;
}
.cta:hover::after{ animation:none; opacity:0; }
@keyframes pulse-gold{
  0%,100%{ opacity:0; }
  50%    { opacity:1; }
}

/* 統計数値のフラッシュイン */
@keyframes count-flash{
  0%  { opacity:0; transform:scale(.85); }
  60% { transform:scale(1.06); }
  100%{ opacity:1; transform:scale(1); }
}
.pstat .n[data-counted],
.stat-box .n[data-counted],
.band-fact .huge[data-counted]{
  animation:count-flash .6s ease both;
}

/* カードホバー：浮き上がり */
.card{
  transition:box-shadow .25s, transform .25s;
}
.card:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 28px rgba(0,0,0,.1);
}

/* メリットカードホバー */
.merit{
  transition:transform .25s, box-shadow .25s;
}
.merit:hover{
  transform:translateY(-4px);
  box-shadow:0 10px 26px rgba(0,0,0,.1);
}

/* サービス行ホバー：左ボーダーアクセント */
.service{
  position:relative;
  transition:background .2s;
}
.service::before{
  content:"";
  position:absolute;left:0;top:0;bottom:0;
  width:3px;background:var(--gold);
  transform:scaleY(0);transform-origin:bottom;
  transition:transform .25s ease;
}
.service:hover{ background:rgba(217,128,32,.04); }
.service:hover::before{ transform:scaleY(1); }

/* フローステップホバー */
.flow-item{
  transition:background .2s;
}
.flow-item:hover{
  background:rgba(217,128,32,.03);
}
