/* =============================================
   東京の太陽光・蓄電池見積もり相談室 – 共通スタイル
   ============================================= */
:root {
  --navy: #073a78;
  --blue: #0d71b9;
  --sky: #eaf8ff;
  --teal: #09a99a;
  --teal-dark: #008a82;
  --yellow: #ffd65a;
  --orange: #f28c00;
  --red: #d63031;
  --ink: #12304f;
  --muted: #5f7288;
  --line: #cfe5f5;
  --card: #ffffff;
  --shadow: 0 16px 40px rgba(11,74,122,.12);
  --shadow-sm: 0 4px 16px rgba(11,74,122,.08);
  font-family: -apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic","YuGothic","Noto Sans JP",sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:var(--ink);background:#f7fbff;letter-spacing:0;line-height:1.7}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4{line-height:1.35;margin:0 0 .6em}
p{margin:0 0 1em}
ul,ol{margin:0 0 1em;padding-left:1.5em}

/* ── ヘッダー ─ */
.site-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:20px;min-height:76px;padding:12px clamp(16px,4vw,64px);background:rgba(255,255,255,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(14px)}
.brand{display:flex;align-items:center;gap:12px;min-width:0;flex-shrink:0}
.brand-mark{display:grid;place-items:center;width:44px;height:44px;color:#fff;font-size:22px;font-weight:800;background:linear-gradient(135deg,#18b7a3,#0870bc);border-radius:11px;box-shadow:0 6px 18px rgba(0,137,168,.24);flex-shrink:0}
.brand strong{display:block;color:var(--navy);font-size:17px;line-height:1.15;white-space:nowrap}
.brand small{display:block;margin-top:2px;color:#42617d;font-size:11px;font-weight:700;white-space:nowrap}
.nav{display:flex;justify-content:center;flex:1;gap:clamp(12px,1.8vw,28px);color:#173452;font-size:13px;font-weight:800;overflow-x:auto}
.nav a:hover{color:var(--teal-dark)}
.header-cta,.btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 20px;border-radius:999px;font-weight:900;line-height:1.2;font-size:14px;cursor:pointer;border:none;transition:opacity .15s,box-shadow .15s;white-space:nowrap}
.header-cta,.btn.primary{color:#fff;background:linear-gradient(135deg,#17b89f,#008f86);box-shadow:0 8px 20px rgba(6,155,145,.24)}
.btn.primary:hover,.header-cta:hover{opacity:.9}
.btn.secondary{color:var(--navy);background:#fff;border:2px solid #116ab0;box-shadow:none}
.btn.secondary:hover{background:var(--sky)}
.btn.outline{color:var(--navy);background:transparent;border:2px solid #cfe5f5;box-shadow:none}
.btn.outline:hover{background:var(--sky)}
.btn.yellow{color:#073a78;background:var(--yellow);box-shadow:0 10px 22px rgba(111,87,4,.2)}
.btn.danger{color:#fff;background:var(--red);box-shadow:0 8px 20px rgba(214,48,49,.22)}
.btn.full{width:100%;min-height:58px;font-size:16px}
.btn.lg{min-height:60px;min-width:280px;font-size:16px;padding:0 32px}

/* ── 共通 ─ */
.page-wrap{max-width:1160px;margin:0 auto;padding:0 18px}
.section{padding:48px 0}
.section-title{text-align:center;margin-bottom:32px}
.section-title .label{display:inline-block;margin-bottom:8px;color:var(--blue);font-size:13px;font-weight:900}
.section-title h2{color:var(--navy);font-size:clamp(22px,2.6vw,34px);margin-bottom:0}

/* ── ヒーロー ─ */
.hero{position:relative;overflow:hidden;padding:56px clamp(16px,5vw,72px) 40px;background:radial-gradient(circle at 94% 10%,rgba(72,181,224,.18),transparent 22%),linear-gradient(108deg,#fff 0%,#edfaff 52%,#daf4ff 100%)}
.hero::after{content:"";position:absolute;inset:auto 0 0;height:80px;background-image:radial-gradient(rgba(6,103,168,.12) 1px,transparent 1px);background-size:12px 12px;pointer-events:none}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:minmax(320px,.92fr) minmax(380px,1.08fr);align-items:center;gap:28px;max-width:1200px;margin:0 auto}
.eyebrow{width:fit-content;margin:0 0 16px;padding:7px 16px;color:var(--teal-dark);font-size:13px;font-weight:900;background:rgba(9,169,154,.1);border-radius:999px}
.hero h1{margin:0;color:var(--navy);font-size:clamp(32px,3.8vw,56px);line-height:1.25}
.hero h1 .accent{color:var(--teal-dark)}
.hero-questions{margin:24px 0 8px;display:flex;flex-direction:column;gap:10px}
.hero-questions p{margin:0;display:flex;align-items:center;gap:10px;color:var(--navy);font-size:18px;font-weight:900}
.hero-questions p::before{content:"？";display:grid;place-items:center;width:28px;height:28px;border-radius:50%;background:var(--teal);color:#fff;font-size:14px;flex-shrink:0}
.hero-subtitle{margin:20px 0 28px;color:#244865;font-size:15px;font-weight:700}
.hero-actions{display:flex;flex-direction:column;gap:14px}
.hero-actions .btn{width:100%;max-width:380px;min-height:54px;font-size:15px}
.trust-note{margin-top:18px;color:#52718c;font-size:12px;font-weight:700}
.trust-note::before{content:"※ "}
.hero-visual{position:relative}
.hero-visual img{width:100%;max-height:500px;object-fit:contain;filter:drop-shadow(0 24px 36px rgba(20,95,142,.18))}
.bubble{position:absolute;display:grid;place-items:center;padding:16px;color:var(--navy);font-size:13px;font-weight:900;line-height:1.65;text-align:center;background:#fff;border:1px solid #cbe7fb;border-radius:50%;box-shadow:var(--shadow)}
.bubble.top{width:136px;height:136px;top:20px;right:8px}
.bubble.bottom{width:108px;height:108px;right:36px;bottom:52px;font-size:12px}

/* ── フィーチャーストリップ ─ */
.feature-strip{display:grid;grid-template-columns:repeat(3,1fr);max-width:1140px;margin:-6px auto 40px;padding:0 18px;transform:translateY(-8px)}
.feature-strip article{display:flex;align-items:center;gap:16px;min-height:106px;padding:22px 28px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.feature-strip article:first-child{border-radius:14px 0 0 14px}
.feature-strip article:last-child{border-radius:0 14px 14px 0}
.f-icon{display:grid;place-items:center;flex:0 0 56px;width:56px;height:56px;color:#fff;font-size:26px;font-weight:900;background:linear-gradient(135deg,#1ba7d6,#0a4f98);border-radius:16px}
.f-icon.teal{background:linear-gradient(135deg,#1fc9b5,#078c86)}
.feature-strip h3,.feature-strip p{margin:0}
.feature-strip h3{color:var(--navy);font-size:15px}
.feature-strip p{margin-top:5px;color:var(--muted);font-size:12px;font-weight:700;line-height:1.6}

/* ── ファネルカード ─ */
.funnel-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.funnel-card{display:flex;flex-direction:column;padding:28px;border-radius:16px;background:#fff;border:2px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s;text-decoration:none}
.funnel-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.funnel-icon{display:grid;place-items:center;width:56px;height:56px;border-radius:16px;font-size:28px;margin-bottom:16px;background:linear-gradient(135deg,#1ba7d6,#0a4f98);color:#fff}
.funnel-icon.green{background:linear-gradient(135deg,#1fc9b5,#078c86)}
.funnel-icon.orange{background:linear-gradient(135deg,#f5a623,#e07b00)}
.funnel-icon.red{background:linear-gradient(135deg,#e17055,#c0392b)}
.funnel-card h3{color:var(--navy);font-size:19px;margin-bottom:8px}
.funnel-card p{color:var(--muted);font-size:13px;line-height:1.75;flex:1;margin-bottom:0}
.funnel-card .cta-link{margin-top:18px;display:inline-flex;align-items:center;gap:6px;color:var(--teal-dark);font-size:13px;font-weight:900}
.funnel-tag{display:inline-block;margin-bottom:10px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:900;background:rgba(9,169,154,.1);color:var(--teal-dark)}
.funnel-tag.orange-tag{background:rgba(240,168,0,.12);color:#9a6700}
.funnel-tag.red-tag{background:rgba(214,48,49,.1);color:#b02222}

/* ── 記事クラスターグリッド ─ */
.cluster-section{background:#fff;border-top:1px solid var(--line)}
.cluster-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.article-card{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .18s,box-shadow .18s}
.article-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.article-card-head{padding:16px 18px 14px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}
.article-card-head .cat-icon{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;font-size:16px;background:linear-gradient(135deg,#1ba7d6,#0a4f98);color:#fff;flex-shrink:0}
.article-card-head .cat-icon.teal{background:linear-gradient(135deg,#1fc9b5,#078c86)}
.article-card-head .cat-icon.orange{background:linear-gradient(135deg,#f5a623,#e07b00)}
.article-card-head .cat-icon.red{background:linear-gradient(135deg,#e17055,#c0392b)}
.article-card-head h4{color:var(--navy);font-size:13px;margin:0}
.article-list{padding:10px 18px 16px;list-style:none;margin:0;padding-left:18px}
.article-list li{border-bottom:1px dashed var(--line)}
.article-list li:last-child{border-bottom:none}
.article-list a{display:block;padding:9px 0;color:#1a4070;font-size:12px;font-weight:700;line-height:1.45}
.article-list a:hover{color:var(--teal-dark)}
.article-list a::before{content:"→ ";color:var(--teal);font-size:11px}

/* ── 補助金テーブル ─ */
.subsidy-table-wrap{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm)}
.subsidy-table-head{padding:20px 24px 14px;background:linear-gradient(90deg,#e6f6ff,#fff);border-bottom:1px solid var(--line)}
.subsidy-table-head h3{color:var(--navy);font-size:21px;margin-bottom:4px}
.subsidy-table-head p{color:var(--muted);font-size:12px;margin:0;font-weight:700}
.s-table{width:100%;border-collapse:collapse}
.s-table th{background:#edf7fe;color:#21415c;font-size:12px;font-weight:900;padding:12px 16px;text-align:left;border-bottom:1px solid var(--line);border-right:1px solid var(--line)}
.s-table th:last-child{border-right:none}
.s-table td{padding:15px 16px;font-size:13px;font-weight:700;border-bottom:1px solid var(--line);border-right:1px solid var(--line);vertical-align:middle;line-height:1.5}
.s-table td:last-child{border-right:none}
.s-table tr:last-child td{border-bottom:none}
.s-table td strong{display:block;color:var(--navy);font-size:14px;margin-bottom:2px}
.s-table td small{color:var(--muted);font-size:11px}
.s-table .amount{color:var(--teal-dark);font-size:17px}

/* ── テスティモニアル ─ */
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.voice-card{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm);padding:22px 22px 18px 88px;position:relative;min-height:150px}
.voice-avatar{position:absolute;left:22px;top:22px;width:50px;height:50px;display:grid;place-items:center;border-radius:50%;font-weight:900;background:#e8f4ff;border:2px solid #b9dbf4;color:var(--navy)}
.voice-avatar.f{background:#fff0f5;border-color:#f2bfd0;color:#8a3150}
.voice-card h4{color:var(--navy);font-size:14px;margin-bottom:6px}
.voice-card p{color:var(--muted);font-size:13px;line-height:1.7;margin:0}
.voice-card .meta{color:var(--navy);font-size:11px;font-weight:900;margin-top:8px}

/* ── FAQ ─ */
.faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 18px}
details{background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-sm);padding:0 18px}
summary{position:relative;min-height:50px;padding:14px 34px 14px 0;color:var(--navy);font-weight:900;font-size:14px;cursor:pointer;list-style:none}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";position:absolute;right:2px;top:10px;color:var(--blue);font-size:22px}
details[open] summary::after{content:"−"}
details p{margin:0 0 14px;color:var(--muted);font-size:13px;line-height:1.75}

/* ── ファイナルCTA ─ */
.final-cta{display:flex;align-items:center;justify-content:center;gap:40px;min-height:180px;padding:40px 24px;background:linear-gradient(90deg,rgba(10,124,190,.93),rgba(9,183,166,.89));color:#fff;text-align:center}
.final-cta h2{margin:0;font-size:clamp(22px,2.8vw,36px)}
.final-cta p{margin:8px 0 0;font-size:16px;font-weight:800}

/* ── フッター ─ */
.site-footer{background:var(--navy);color:rgba(255,255,255,.7);padding:40px 24px 24px;text-align:center;font-size:13px;font-weight:700}
.site-footer strong{color:#fff;font-size:16px;display:block;margin-bottom:8px}
.footer-nav{display:flex;justify-content:center;flex-wrap:wrap;gap:4px 20px;margin:16px 0}
.footer-nav a{color:rgba(255,255,255,.6);font-size:12px}
.footer-nav a:hover{color:#fff}
.footer-disc{margin-top:18px;font-size:11px;color:rgba(255,255,255,.4);line-height:1.6}

/* ══ 記事ページ ══ */
.article-page{background:#f7fbff}
.article-layout{display:grid;grid-template-columns:1fr 280px;gap:32px;max-width:1140px;margin:0 auto;padding:28px 18px 56px}
.breadcrumb{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:20px;font-size:12px;font-weight:700;color:var(--muted)}
.breadcrumb a{color:var(--blue)}
.article-main{min-width:0}
.article-header{margin-bottom:24px}
.article-header .cat-label{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:999px;font-size:12px;font-weight:900;background:rgba(9,169,154,.1);color:var(--teal-dark);margin-bottom:14px}
.article-header .cat-label.orange{background:rgba(240,168,0,.12);color:#9a6700}
.article-header .cat-label.red{background:rgba(214,48,49,.1);color:#b02222}
.article-header h1{font-size:clamp(22px,2.8vw,36px);color:var(--navy);line-height:1.35;margin-bottom:14px}
.article-meta{display:flex;align-items:center;gap:16px;font-size:12px;font-weight:700;color:var(--muted);padding-bottom:14px;border-bottom:1px solid var(--line)}
.article-meta time{color:var(--blue)}
.article-body{font-size:15px;line-height:1.88;color:var(--ink)}
.article-body h2{font-size:21px;color:var(--navy);margin:38px 0 14px;padding:14px 18px;background:linear-gradient(90deg,#edf7fe,#fff);border-left:4px solid var(--teal);border-radius:0 8px 8px 0}
.article-body h3{font-size:17px;color:var(--navy);margin:26px 0 10px;padding-bottom:7px;border-bottom:2px solid var(--line)}
.article-body h4{font-size:15px;color:var(--navy);margin:18px 0 7px}
.article-body ul{list-style:none;padding:0}
.article-body ul li{padding:6px 0 6px 22px;position:relative;border-bottom:1px dashed var(--line)}
.article-body ul li::before{content:"▸";position:absolute;left:0;color:var(--teal);font-size:12px;top:9px}
.article-body ol li{padding:4px 0}

/* 記事コンポーネント */
.conclusion-box{background:linear-gradient(108deg,#e8f7ff,#f0fff8);border:2px solid var(--teal);border-radius:14px;padding:22px 26px;margin-bottom:30px}
.conclusion-box .box-label{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:900;color:var(--teal-dark);margin-bottom:8px}
.conclusion-box h3{color:var(--navy);font-size:16px;margin-bottom:8px}
.conclusion-box p{color:#1a3a5c;font-size:14px;line-height:1.8;margin:0}
.warning-box{background:#fff9e6;border:2px solid #f0a800;border-radius:12px;padding:18px 22px;margin:22px 0}
.warning-box .box-label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:900;color:#9a6700;margin-bottom:6px}
.warning-box p{color:#5c3d00;font-size:13px;line-height:1.75;margin:0}
.danger-box{background:#fff0f0;border:2px solid var(--red);border-radius:12px;padding:18px 22px;margin:22px 0}
.danger-box .box-label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:900;color:var(--red);margin-bottom:6px}
.danger-box p{color:#5a0e0e;font-size:13px;line-height:1.75;margin:0}
.info-box{background:#e8f4ff;border-left:4px solid var(--blue);border-radius:0 12px 12px 0;padding:16px 20px;margin:18px 0}
.info-box p{color:#1a3a5c;font-size:13px;line-height:1.75;margin:0}

/* チェックリスト */
.check-list{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 26px;margin:22px 0;box-shadow:var(--shadow-sm)}
.check-list h4{color:var(--navy);font-size:16px;margin-bottom:14px}
.check-list ul{list-style:none;padding:0;margin:0}
.check-list ul li{border-bottom:1px solid var(--line);padding:0}
.check-list ul li:last-child{border-bottom:none}
.check-list ul li::before{display:none}
.check-list label{display:flex;align-items:flex-start;gap:12px;cursor:pointer;font-size:14px;font-weight:700;color:var(--ink);padding:11px 0;width:100%}
.check-list input[type="checkbox"]{width:20px;height:20px;flex-shrink:0;margin-top:1px;accent-color:var(--teal);cursor:pointer}
.check-list input[type="checkbox"]:checked+span{text-decoration:line-through;color:var(--muted)}

/* インラインCTA */
.inline-cta{background:linear-gradient(108deg,var(--navy),#0a5596);border-radius:14px;padding:26px 30px;margin:30px 0;color:#fff;display:flex;align-items:center;justify-content:space-between;gap:20px}
.inline-cta h4{font-size:16px;margin-bottom:5px}
.inline-cta p{font-size:13px;opacity:.85;margin:0}
.inline-cta .btn{flex-shrink:0;background:#fff;color:var(--navy);box-shadow:none}

/* 危険ワードリスト */
.danger-word-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:14px 0}
.danger-word{display:flex;align-items:flex-start;gap:10px;padding:13px 15px;border-radius:10px;background:#fff0f0;border:1px solid #f5c6c6;font-size:13px;font-weight:900;color:#7a0000;line-height:1.4}
.danger-word::before{content:"⚠";flex-shrink:0;color:var(--red)}

/* サイドバー */
.article-sidebar{display:flex;flex-direction:column;gap:18px}
.sidebar-box{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden}
.sidebar-box-head{padding:12px 16px;background:linear-gradient(90deg,#edf7fe,#fff);border-bottom:1px solid var(--line);color:var(--navy);font-size:13px;font-weight:900}
.sidebar-box-body{padding:14px 16px}
.sidebar-cta{background:linear-gradient(135deg,#17b89f,#008f86);color:#fff;padding:22px 16px;text-align:center}
.sidebar-cta h4{font-size:14px;margin-bottom:8px}
.sidebar-cta p{font-size:12px;opacity:.88;margin-bottom:12px}
.sidebar-cta .btn{width:100%;min-height:44px;font-size:12px;background:#fff;color:var(--teal-dark);box-shadow:none}
.toc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}
.toc-list li{font-size:12px;font-weight:700}
.toc-list a{display:block;padding:6px 8px;color:var(--blue);border-radius:6px}
.toc-list a:hover{background:var(--sky)}
.related-list{list-style:none;padding:0;margin:0}
.related-list li{border-bottom:1px dashed var(--line)}
.related-list li:last-child{border-bottom:none}
.related-list a{display:block;padding:9px 0;color:#1a4070;font-size:12px;font-weight:700;line-height:1.4}
.related-list a:hover{color:var(--teal-dark)}
.related-list a::before{content:"→ ";color:var(--teal);font-size:11px}

/* ══ LPページ ══ */
.lp-page{background:#f7fbff}
.lp-hero{padding:56px clamp(16px,5vw,72px) 48px;background:linear-gradient(108deg,#fff 0%,#edfaff 52%,#daf4ff 100%);text-align:center}
.lp-hero .tag{display:inline-block;padding:6px 16px;background:rgba(9,169,154,.12);color:var(--teal-dark);border-radius:999px;font-size:12px;font-weight:900;margin-bottom:16px}
.lp-hero .tag.red-tag{background:rgba(214,48,49,.1);color:#b02222}
.lp-hero .tag.orange-tag{background:rgba(240,168,0,.12);color:#9a6700}
.lp-hero h1{font-size:clamp(26px,3.6vw,48px);color:var(--navy);line-height:1.28;margin-bottom:16px}
.lp-hero h1 em{color:var(--teal-dark);font-style:normal}
.lp-hero h1 .red-em{color:var(--red);font-style:normal}
.lp-hero .lead{font-size:16px;color:#244865;font-weight:700;line-height:1.85;max-width:640px;margin:0 auto 26px}
.lp-hero .btn{min-height:60px;min-width:300px;font-size:16px}
.lp-trust{margin-top:14px;font-size:12px;color:var(--muted);font-weight:700}
.lp-content{max-width:820px;margin:0 auto;padding:48px 18px 64px}
.lp-section{margin-bottom:48px}
.lp-section h2{font-size:23px;color:var(--navy);margin-bottom:18px;padding:14px 20px;background:linear-gradient(90deg,#edf7fe,#fff);border-left:4px solid var(--teal);border-radius:0 10px 10px 0}
.lp-section h3{font-size:18px;color:var(--navy);margin-bottom:10px}
.lp-section p{font-size:15px;color:#1a3a5c;line-height:1.85}
.lp-step-grid{display:flex;flex-direction:column;gap:18px}
.lp-step{display:grid;grid-template-columns:52px 1fr;gap:16px;align-items:flex-start;padding:22px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm)}
.lp-step-no{display:grid;place-items:center;width:52px;height:52px;border-radius:50%;background:var(--teal);color:#fff;font-size:22px;font-weight:900;flex-shrink:0}
.lp-step h4{color:var(--navy);font-size:16px;margin-bottom:6px}
.lp-step p{color:var(--muted);font-size:13px;line-height:1.75;margin:0}
.lp-form-section{background:linear-gradient(108deg,var(--navy),#0a5596);border-radius:20px;padding:40px;color:#fff;text-align:center}
.lp-form-section h3{font-size:23px;margin-bottom:8px}
.lp-form-section p{font-size:14px;opacity:.88;margin-bottom:22px}
.trust-list{display:flex;justify-content:center;gap:22px;margin-bottom:22px;flex-wrap:wrap}
.trust-list span{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;opacity:.9}
.trust-list span::before{content:"✓";color:#4dd9ca;font-weight:900}
.lp-form-section .btn{min-height:64px;min-width:320px;font-size:17px}

/* ══ 記事の読みやすさ強化 ══ */
.article-hero-visual{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:20px;align-items:stretch;margin:20px 0 30px;padding:22px;background:linear-gradient(108deg,#ffffff,#eefaff);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm);overflow:hidden}
.article-hero-copy{display:flex;flex-direction:column;justify-content:center;min-width:0}
.article-hero-copy .visual-kicker{width:fit-content;margin-bottom:10px;padding:5px 12px;border-radius:999px;background:rgba(9,169,154,.1);color:var(--teal-dark);font-size:11px;font-weight:900}
.article-hero-copy h2{margin:0 0 10px;padding:0;background:none;border:0;border-radius:0;color:var(--navy);font-size:22px;line-height:1.45}
.article-hero-copy p{margin:0;color:#31526f;font-size:14px;font-weight:700;line-height:1.8}
.article-visual-card{position:relative;min-height:180px;padding:18px;border-radius:16px;background:linear-gradient(145deg,#0b4f98,#12aa9c);color:#fff;overflow:hidden}
.article-visual-card::before{content:"";position:absolute;inset:14px 18px auto auto;width:92px;height:92px;border-radius:50%;background:rgba(255,255,255,.14)}
.article-visual-card::after{content:"";position:absolute;left:-28px;bottom:-34px;width:140px;height:140px;border-radius:50%;background:rgba(255,214,90,.22)}
.visual-meter{position:relative;z-index:1;display:flex;align-items:flex-end;gap:10px;height:86px;margin:22px 0 14px}
.visual-meter span{display:block;flex:1;border-radius:10px 10px 0 0;background:rgba(255,255,255,.9)}
.visual-meter span:nth-child(1){height:42%}
.visual-meter span:nth-child(2){height:68%;background:var(--yellow)}
.visual-meter span:nth-child(3){height:52%}
.visual-meter span:nth-child(4){height:86%;background:#fff}
.article-visual-card strong{position:relative;z-index:1;display:block;font-size:22px;line-height:1.25}
.article-visual-card small{position:relative;z-index:1;display:block;margin-top:8px;font-size:12px;line-height:1.5;opacity:.86}
.article-point-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:22px 0 30px}
.article-point{padding:16px 16px 14px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm)}
.article-point b{display:block;margin-bottom:7px;color:var(--navy);font-size:14px;line-height:1.45}
.article-point span{display:block;color:var(--muted);font-size:12px;font-weight:700;line-height:1.65}
.article-snapshot{margin:24px 0;padding:18px 20px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm)}
.article-snapshot h3{margin:0 0 12px;padding:0;border:0;color:var(--navy);font-size:16px}
.snapshot-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:0;padding:0;list-style:none}
.article-body .snapshot-list li{display:flex;align-items:flex-start;gap:10px;padding:12px 13px;background:#f7fbff;border:1px solid #dcecf8;border-radius:10px;color:#234665;font-size:13px;font-weight:800;line-height:1.55}
.article-body .snapshot-list li::before{content:"";position:static;display:grid;place-items:center;flex:0 0 9px;width:9px;height:9px;margin-top:7px;border-radius:50%;background:var(--teal)}
.source-panel{margin:24px 0;padding:16px 18px;background:#f7fbff;border:1px solid var(--line);border-radius:12px;color:#31526f;font-size:12px;font-weight:700;line-height:1.75}
.source-panel strong{display:block;margin-bottom:4px;color:var(--navy);font-size:13px}

/* 競合記事を踏まえたプロ寄せの本文トーン */
.article-page{background:#eef3f7}
.article-layout{grid-template-columns:minmax(0,820px) 282px;gap:34px;align-items:start}
.article-main{background:#fff;border:1px solid #d8e2ea;border-radius:10px;padding:30px 38px 42px;box-shadow:0 10px 28px rgba(20,44,67,.06)}
.article-header{margin-bottom:18px}
.article-header .cat-label{background:#eef5f8;color:#34566f;border:1px solid #d7e5ec;border-radius:4px}
.article-header h1{color:#172b3a;font-size:clamp(26px,3vw,38px);letter-spacing:0;line-height:1.45}
.article-meta{color:#697987;border-bottom:1px solid #dce5ec}
.article-body{color:#243746;font-size:16px;line-height:1.95}
.article-body p{color:#243746}
.article-body h2{margin:44px 0 16px;padding:0 0 10px;background:none;border-left:0;border-bottom:3px solid #1d5f8f;border-radius:0;color:#172b3a;font-size:24px}
.article-body h3{margin:30px 0 12px;padding:0;border-bottom:0;color:#213848;font-size:18px}
.article-body ul li{border-bottom:1px solid #edf2f5;color:#2f4352}
.article-body ul li::before{color:#1d5f8f}
.article-hero-visual{grid-template-columns:1fr;margin:12px 0 24px;padding:0;background:#fff;border:0;border-radius:0;box-shadow:none}
.article-hero-copy{padding:18px 20px;background:#f6f9fb;border-left:5px solid #1d5f8f;border-radius:6px}
.article-hero-copy .visual-kicker{background:#e7f0f5;color:#26495f;border-radius:4px}
.article-hero-copy h2{color:#172b3a;font-size:22px}
.article-hero-copy p{color:#42586a;font-weight:600}
.article-visual-card{display:none}
.article-point-grid{gap:10px;margin:18px 0 22px}
.article-point{border:1px solid #dce5ec;border-radius:8px;box-shadow:none;background:#fff}
.article-point b{color:#172b3a}
.article-point span{color:#526879}
.article-snapshot{border:1px solid #dce5ec;border-radius:8px;box-shadow:none;background:#fff}
.article-snapshot h3{color:#172b3a}
.article-body .snapshot-list li{background:#f8fafb;border-color:#e1e9ef;color:#2b4050;border-radius:6px}
.article-body .snapshot-list li::before{background:#1d5f8f}
.source-panel{background:#f8fafb;border-color:#dce5ec;border-radius:8px;color:#526879}
.source-panel strong{color:#172b3a}
.conclusion-box{background:#f6f9fb;border:1px solid #cfdde7;border-left:5px solid #1d5f8f;border-radius:8px;box-shadow:none}
.conclusion-box .box-label{color:#1d5f8f}
.conclusion-box h3{color:#172b3a;font-size:18px}
.conclusion-box p{color:#2f4352;font-size:15px}
.warning-box{background:#fff8e8;border:1px solid #efcf83;border-left:5px solid #d89400;border-radius:8px}
.danger-box{background:#fff4f2;border:1px solid #efb6ad;border-left:5px solid #c0392b;border-radius:8px}
.info-box{background:#f3f8fb;border-left-color:#1d5f8f;border-radius:0 8px 8px 0}
.inline-cta{background:#f7fafc;border:1px solid #dce5ec;border-radius:8px;color:#172b3a;box-shadow:none}
.inline-cta h4{color:#172b3a}
.inline-cta p{color:#607485;opacity:1}
.inline-cta .btn{background:#0f6b7a;color:#fff;border-radius:6px}
.sidebar-cta{background:#fff;border:1px solid #dce5ec;border-radius:8px;color:#172b3a;text-align:left}
.sidebar-cta h4{color:#172b3a}
.sidebar-cta p{color:#607485;opacity:1}
.sidebar-cta .btn{background:#0f6b7a;color:#fff;border-radius:6px}
.sidebar-box{border-color:#dce5ec;border-radius:8px;box-shadow:none}
.sidebar-box-head{background:#f6f9fb;color:#172b3a}
.article-data-box{margin:24px 0;border:1px solid #dce5ec;border-radius:8px;overflow:hidden;background:#fff}
.article-data-box h3{margin:0;padding:15px 18px;background:#f6f9fb;border-bottom:1px solid #dce5ec;color:#172b3a;font-size:16px}
.article-data-table{width:100%;border-collapse:collapse}
.article-data-table th,.article-data-table td{padding:13px 15px;border-bottom:1px solid #e8eef2;text-align:left;vertical-align:top;font-size:14px;line-height:1.65}
.article-data-table th{width:30%;background:#fbfcfd;color:#172b3a;font-weight:900}
.article-data-table td{color:#2f4352}
.article-data-table tr:last-child th,.article-data-table tr:last-child td{border-bottom:0}

/* エコの王様系の記事メディア表現 */
.article-page{background:#f3f5f7}
.article-layout{grid-template-columns:minmax(0,800px) 300px;max-width:1180px;gap:34px;padding-top:30px}
.article-main{background:#fff;border:1px solid #e2e6ea;border-radius:0;padding:34px 42px 46px;box-shadow:0 2px 10px rgba(20,35,48,.05)}
.breadcrumb{color:#7a8791}
.article-header .cat-label{display:inline-block;padding:6px 12px;background:#fff3cf;border:1px solid #f0c65a;color:#8a5b00;border-radius:3px}
.article-header .cat-label.red{background:#fff0eb;border-color:#efb59f;color:#a9441f}
.article-header .cat-label.orange{background:#fff3cf;border-color:#f0c65a;color:#8a5b00}
.article-header h1{margin-top:8px;color:#222;font-size:clamp(28px,3vw,40px);font-weight:900;line-height:1.48}
.article-meta{gap:10px 16px;flex-wrap:wrap;color:#777;border-bottom:0;padding-bottom:0;margin-top:10px}
.article-meta time{color:#777}
.article-eyecatch{margin:26px 0 22px;border:1px solid #e4e8ec;background:#f7fafc}
.article-eyecatch img{width:100%;max-height:360px;object-fit:cover}
.article-lead{margin:0 0 24px;color:#333;font-size:16px;line-height:2;font-weight:500}
.article-toc-box{margin:26px 0 32px;border:1px solid #e0e0e0;background:#fff;border-radius:2px}
.article-toc-box .toc-title{padding:13px 18px;background:#f7f7f7;border-bottom:1px solid #e0e0e0;color:#333;font-size:15px;font-weight:900}
.article-toc-box ol{margin:0;padding:12px 22px 14px 42px}
.article-toc-box li{padding:7px 0;color:#333;font-size:14px;font-weight:700;border-bottom:1px dotted #d8d8d8}
.article-toc-box li:last-child{border-bottom:0}
.article-toc-box a{color:#135c95;text-decoration:none}
.article-body{color:#333;font-size:16px;line-height:2}
.article-body p{color:#333}
.article-body a{color:#006fb7;text-decoration:underline;text-underline-offset:3px}
.article-body h2{position:relative;margin:48px 0 18px;padding:12px 16px 12px 18px;background:#f6a800;border:0;border-radius:0;color:#fff;font-size:24px;line-height:1.45}
.article-body h2::before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:#d98100}
.article-body h3{margin:32px 0 12px;padding:0 0 8px;border-bottom:2px solid #f0c65a;color:#333;font-size:20px}
.article-body ul li{padding:8px 0 8px 24px;border-bottom:1px dashed #ddd;color:#333}
.article-body ul li::before{content:"";top:18px;width:8px;height:8px;border-radius:50%;background:#f6a800}
.conclusion-box{margin:0 0 30px;padding:22px 24px;background:#fffdf4;border:2px solid #f0c65a;border-radius:2px}
.conclusion-box .box-label{color:#b07000}
.conclusion-box h3{margin:0 0 8px;padding:0;border:0;color:#333;font-size:20px}
.conclusion-box p{color:#333;font-size:15px;line-height:1.9}
.subsidy-table-wrap,.article-data-box{border:1px solid #ddd;border-radius:0;box-shadow:none}
.subsidy-table-head,.article-data-box h3{background:#fff7dd;color:#333;border-bottom:1px solid #e2d2a0}
.s-table th,.article-data-table th{background:#fff7dd;color:#333}
.s-table td,.article-data-table td{color:#333}
.warning-box{background:#fffdf4;border:2px solid #f0c65a;border-radius:2px}
.warning-box .box-label{color:#b07000}
.danger-box{background:#fff4ef;border:2px solid #e28b6d;border-radius:2px}
.info-box{background:#f7fafc;border-left:5px solid #5996c8;border-radius:0}
.danger-word{background:#fff4ef;border-color:#efb59f;border-radius:2px;color:#7b260c}
.check-list{border:1px solid #ddd;border-radius:2px;box-shadow:none}
.check-list h4{color:#333}
.inline-cta{margin:34px 0;padding:24px;background:#fff8df;border:2px solid #f0c65a;border-radius:2px;color:#333}
.inline-cta h4{color:#333;font-size:18px}
.inline-cta p{color:#555}
.inline-cta .btn{background:#f08a00;color:#fff;border-radius:3px}
.article-summary-box{margin:44px 0 28px;padding:0 24px 22px;background:#fffdf4;border:2px solid #f0c65a;border-radius:2px}
.article-summary-box h2{margin:0 -24px 18px;padding:12px 18px;background:#f6a800;color:#fff;font-size:23px}
.article-summary-box h2::before{display:none}
.article-summary-box p{margin-bottom:8px}
.article-summary-box ul{margin-bottom:0}
.sidebar-cta{background:#fff8df;border:2px solid #f0c65a;border-radius:2px;color:#333}
.sidebar-cta h4{color:#333;font-size:16px}
.sidebar-cta p{color:#555}
.sidebar-cta .btn{background:#f08a00;color:#fff;border-radius:3px}
.sidebar-box{border:1px solid #ddd;border-radius:2px;background:#fff}
.sidebar-box-head{background:#f7f7f7;color:#333;border-bottom:1px solid #ddd}
.toc-list a,.related-list a{color:#135c95}

/* エコの王様寄せ：トップ/LP/一覧のメディア化 */
body{background:#f3f5f7;color:#333}
.site-header{background:#fff;border-top:5px solid #f6a800;border-bottom:1px solid #ddd;box-shadow:0 2px 8px rgba(0,0,0,.04);backdrop-filter:none}
.brand-mark{background:#f6a800;border-radius:2px;box-shadow:none;color:#fff}
.brand strong{color:#222}
.brand small{color:#777}
.nav{color:#333}
.nav a{padding:8px 0;border-bottom:2px solid transparent}
.nav a:hover{color:#c77700;border-bottom-color:#f6a800}
.header-cta,.btn.primary,.btn.yellow{background:#f08a00;color:#fff;border-radius:3px;box-shadow:none}
.btn.secondary,.btn.outline{border:1px solid #d4d4d4;background:#fff;color:#333;border-radius:3px}
.btn.danger{background:#c94827;border-radius:3px;box-shadow:none}
.btn:hover{opacity:.9}
.hero{padding:38px clamp(16px,4vw,64px);background:#fff;border-bottom:1px solid #ddd}
.hero::after{display:none}
.hero-inner{grid-template-columns:minmax(0,1fr) minmax(320px,460px);gap:34px}
.eyebrow{padding:5px 10px;background:#fff3cf;border:1px solid #f0c65a;color:#8a5b00;border-radius:3px}
.hero h1{color:#222;font-size:clamp(30px,3.6vw,48px);line-height:1.45}
.hero h1 .accent{color:#d98100}
.hero-questions{gap:6px;margin:20px 0 10px}
.hero-questions p{color:#333;font-size:16px;font-weight:800}
.hero-questions p::before{content:"";width:8px;height:8px;background:#f6a800}
.hero-subtitle,.trust-note{color:#555}
.hero-actions{display:flex;flex-direction:row;flex-wrap:wrap;gap:10px}
.hero-actions .btn{width:auto;max-width:none;min-height:46px;border-radius:3px}
.hero-visual img{border:1px solid #e3e3e3;box-shadow:none;filter:none;background:#f7f7f7}
.bubble{display:none}
.feature-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin:26px auto 26px;transform:none}
.feature-strip article,.feature-strip article:first-child,.feature-strip article:last-child{border-radius:0;border:1px solid #ddd;box-shadow:none;background:#fff}
.f-icon,.f-icon.teal,.funnel-icon,.funnel-icon.green,.funnel-icon.orange,.funnel-icon.red,.article-card-head .cat-icon,.article-card-head .cat-icon.teal,.article-card-head .cat-icon.orange,.article-card-head .cat-icon.red{background:#f6a800;color:#fff;border-radius:2px;box-shadow:none}
.section{padding:42px 0}
.section[style],.cluster-section{background:#fff!important;border-top:1px solid #ddd!important}
.section-title{text-align:left;margin-bottom:22px;border-left:6px solid #f6a800;padding-left:16px}
.section-title .label{color:#b07000}
.section-title h2{color:#222;font-size:clamp(22px,2.3vw,31px)}
.funnel-grid{gap:16px}
.funnel-card{border:1px solid #ddd;border-radius:0;background:#fff;box-shadow:none;padding:22px}
.funnel-card:hover,.article-card:hover{transform:none;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.funnel-tag,.funnel-tag.orange-tag,.funnel-tag.red-tag{background:#fff3cf;color:#8a5b00;border:1px solid #f0c65a;border-radius:3px}
.funnel-card h3,.article-card-head h4{color:#222}
.funnel-card p{color:#555}
.cta-link{color:#006fb7!important}
.article-card{border:1px solid #ddd;border-radius:0;box-shadow:none}
.article-card-head{background:#f7f7f7;border-bottom:1px solid #ddd}
.article-list a{color:#135c95;font-size:13px}
.subsidy-table-wrap{border-radius:0;border-color:#ddd}
.subsidy-table-head{background:#fff7dd}
.s-table th{background:#fff7dd;color:#333}
.voice-card{border:1px solid #ddd;border-radius:0;box-shadow:none;background:#fff}
.voice-avatar,.voice-avatar.f{background:#fff3cf;border-color:#f0c65a;color:#8a5b00}
details{border:1px solid #ddd;border-radius:0;box-shadow:none}
summary{color:#333}
summary::after{color:#f08a00}
.final-cta{background:#fff7dd;color:#333;border-top:2px solid #f0c65a;border-bottom:2px solid #f0c65a}
.final-cta h2{color:#222}
.final-cta p{color:#555}
.lp-page{background:#f3f5f7}
.lp-hero{background:#fff;border-bottom:1px solid #ddd;text-align:left;padding:42px clamp(16px,5vw,72px)}
.lp-hero .tag,.lp-hero .tag.orange-tag,.lp-hero .tag.red-tag{background:#fff3cf;color:#8a5b00;border:1px solid #f0c65a;border-radius:3px}
.lp-hero h1{color:#222;font-size:clamp(30px,3.2vw,44px)}
.lp-hero h1 em,.lp-hero h1 .red-em{color:#d98100}
.lp-hero .lead{margin-left:0;color:#444}
.lp-trust{color:#777}
.lp-content{max-width:900px;background:#fff;border:1px solid #ddd;margin:28px auto 56px;padding:36px 38px}
.lp-section h2{background:#f6a800;color:#fff;border-left:0;border-radius:0;padding:12px 16px;font-size:23px}
.lp-section h3{color:#333}
.lp-section p{color:#333}
.lp-step{border:1px solid #ddd;border-radius:0;box-shadow:none}
.lp-step-no{background:#f6a800!important;border-radius:2px}
.lp-form-section{background:#fff8df;border:2px solid #f0c65a;border-radius:0;color:#333}
.lp-form-section h3{color:#333}
.lp-form-section p{color:#555;opacity:1}
.trust-list span{color:#555;opacity:1}
.trust-list span::before{color:#f08a00}
.check-list{border-radius:0}
.danger-word-list{gap:8px}
.page-wrap .feature-strip + *{margin-top:0}
main [style*="linear-gradient(108deg,#e8f7ff"],main [style*="linear-gradient(108deg,#fff,#edfaff"],main [style*="linear-gradient(108deg,#fff 0%"]{background:#fff!important;border-color:#ddd!important;border-radius:0!important}
main [style*="border-radius:12px"],main [style*="border-radius:14px"],main [style*="border-radius:18px"]{border-radius:0!important}
main [style*="box-shadow"]{box-shadow:none!important}

/* ══ メディアクエリ ══ */
@media(max-width:1060px){
  .site-header{flex-wrap:wrap}
  .nav{order:3;justify-content:flex-start;width:100%;overflow-x:auto;padding-bottom:4px}
  .hero-inner{grid-template-columns:1fr}
  .hero-visual{order:-1}
  .hero-actions .btn{max-width:none}
  .feature-strip,.cluster-grid,.voice-grid{grid-template-columns:1fr}
  .funnel-grid{grid-template-columns:repeat(2,1fr)}
  .feature-strip article,.feature-strip article:first-child,.feature-strip article:last-child{border-radius:14px;border:1px solid var(--line)}
  .feature-strip{gap:12px;transform:none;margin-top:0}
  .article-layout{grid-template-columns:1fr}
  .article-sidebar{display:none}
  .faq-grid{grid-template-columns:1fr}
  .final-cta{flex-direction:column;gap:20px}
  .inline-cta{flex-direction:column}
  .danger-word-list{grid-template-columns:1fr}
  .article-hero-visual{grid-template-columns:1fr}
  .article-point-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .site-header{min-height:auto;padding:12px 16px;gap:10px}
  .brand strong{font-size:14px}
  .brand small,.nav{display:none}
  .header-cta{margin-left:auto;min-height:40px;padding:0 12px;font-size:12px}
  .hero{padding:28px 16px 20px}
  .hero h1{font-size:28px}
  .hero-questions p{font-size:15px}
  .hero-visual,.bubble{display:none}
  .funnel-grid{grid-template-columns:1fr}
  .article-body h2{font-size:18px}
  .article-body h3{font-size:16px}
  .lp-form-section .btn{min-width:0;width:100%}
  .voice-grid{grid-template-columns:1fr}
  .s-table{font-size:11px}
  .s-table th,.s-table td{padding:10px 10px}
  .article-layout{padding:18px 14px 42px}
  .article-hero-visual{margin-top:14px;padding:16px}
  .article-hero-copy h2{font-size:18px}
  .article-visual-card{min-height:150px}
  .snapshot-list{grid-template-columns:1fr}
}

/* Final visual direction: supplied Tokyo battery subsidy nav mock */
:root {
  --navy: #073a78;
  --blue: #1877c9;
  --sky: #eaf8ff;
  --teal: #09a99a;
  --teal-dark: #008a82;
  --yellow: #ffd65a;
  --orange: #f5a623;
  --red: #d84b35;
  --ink: #183a5a;
  --muted: #5f7288;
  --line: #cfe5f5;
  --card: #ffffff;
  --shadow: 0 16px 36px rgba(20, 92, 150, .13);
  --shadow-sm: 0 6px 18px rgba(20, 92, 150, .09);
}
body{background:#f7fcff;color:var(--ink)}
.site-header{min-height:76px;background:#fff;border-top:0;border-bottom:1px solid #d9edf9;box-shadow:0 4px 18px rgba(33,115,176,.07);backdrop-filter:none}
.brand-mark{position:relative;width:48px;height:48px;background:linear-gradient(135deg,#10b7a6,#1e83cf);border-radius:12px;box-shadow:0 8px 18px rgba(7,137,168,.20);font-size:0}
.brand-mark::before{content:"⌂";font-size:26px;color:#fff}
.brand strong{color:var(--navy);font-size:19px;letter-spacing:.02em}
.brand small{color:#3d6788;font-size:12px}
.nav{color:#183a5a;font-size:13px}
.nav a{padding:8px 0;border-bottom:2px solid transparent}
.nav a:hover{color:var(--teal-dark);border-bottom-color:var(--teal)}
.header-cta,.btn.primary{background:linear-gradient(135deg,#14b99f,#009284);border-radius:16px;color:#fff;box-shadow:0 10px 24px rgba(4,151,137,.25)}
.btn.yellow{background:var(--yellow);color:var(--navy);border-radius:16px;box-shadow:0 10px 22px rgba(113,88,4,.18)}
.btn.secondary,.btn.outline{background:#fff;border:2px solid #0b63ad;color:var(--navy);border-radius:16px}
.btn.danger{background:linear-gradient(135deg,#e17055,#c0392b);border-radius:16px}
.hero{position:relative;padding:54px clamp(16px,5vw,72px) 40px;background:radial-gradient(circle at 92% 12%,rgba(255,255,255,.92) 0 64px,transparent 65px),linear-gradient(105deg,#f8fdff 0%,#eaf8ff 50%,#d7f2ff 100%);border-bottom:1px solid #cde8f8;overflow:hidden}
.hero::after{content:"";display:block;position:absolute;inset:auto 0 0;height:110px;background-image:radial-gradient(rgba(0,118,190,.12) 1px,transparent 1px);background-size:13px 13px;pointer-events:none}
.hero-inner{grid-template-columns:minmax(360px,.95fr) minmax(420px,1.05fr);gap:30px;max-width:1200px}
.eyebrow{background:transparent;border:0;color:var(--teal-dark);font-size:13px;padding:0;margin-bottom:14px}
.hero h1{color:var(--navy);font-size:clamp(34px,4.1vw,58px);line-height:1.34;font-weight:900}
.hero h1 .accent{color:var(--teal-dark)}
.hero-subtitle{color:#244865;font-size:15px;font-weight:800;line-height:1.9}
.hero-questions{display:none}
.hero-actions{display:flex;flex-direction:row;flex-wrap:wrap;gap:14px;margin-top:24px}
.hero-actions .btn{min-height:62px;padding:0 28px;border-radius:22px;font-size:16px;width:auto;max-width:none}
.trust-note{color:#4e718f;font-size:12px;font-weight:800}
.hero-visual{display:block;position:relative}
.hero-visual img{width:100%;max-height:510px;object-fit:contain;border:0;background:transparent;box-shadow:none;filter:drop-shadow(0 24px 34px rgba(18,98,150,.18))}
.hero-visual::before{content:"";position:absolute;inset:10% 3% 2% 18%;background:radial-gradient(circle,rgba(255,255,255,.9),rgba(255,255,255,.45) 48%,transparent 70%);border-radius:50%;pointer-events:none}
.hero-visual img{position:relative;z-index:1}
.generated-icon{display:block;width:76px;height:76px;background-image:url("/assets/generated/icon-sprite-brochure-transparent.png");background-size:300% 200%;background-repeat:no-repeat;flex:0 0 76px}
.generated-icon.check{background-position:0% 0%}
.generated-icon.estimate{background-position:50% 0%}
.generated-icon.consult{background-position:100% 0%}
.generated-icon.house{background-position:0% 100%}
.generated-icon.solar{background-position:50% 100%}
.generated-icon.area{background-position:100% 100%}
.generated-advisor{display:block;background:url("/assets/generated/advisor-brochure-transparent.png") center bottom/contain no-repeat}
.f-icon,.funnel-icon,.article-card-head .cat-icon{font-size:0;background-color:transparent!important;background-image:url("/assets/generated/icon-sprite-brochure-transparent.png")!important;background-size:300% 200%!important;background-repeat:no-repeat!important;border-radius:0!important;box-shadow:none!important}
.f-icon.teal,.funnel-icon.green,.article-card-head .cat-icon.teal{background-position:0% 100%!important}
.f-icon:not(.teal),.funnel-icon:not(.green):not(.orange):not(.red),.article-card-head .cat-icon:not(.teal):not(.orange):not(.red){background-position:50% 0%!important}
.funnel-icon.orange,.article-card-head .cat-icon.orange{background-position:50% 100%!important}
.funnel-icon.red,.article-card-head .cat-icon.red{background-position:100% 0%!important}
.voice-avatar{font-size:0;background:url("/assets/generated/advisor-brochure-transparent.png") center bottom/contain no-repeat!important;border:0!important}
.final-cta::after{content:"";display:block;width:180px;height:150px;background:url("/assets/generated/advisor-brochure-transparent.png") center bottom/contain no-repeat}
.final-cta{position:relative}
.lp-form-section{position:relative;overflow:hidden}
.lp-form-section::after{content:"";position:absolute;right:20px;bottom:-8px;width:150px;height:142px;background:url("/assets/generated/advisor-brochure-transparent.png") center bottom/contain no-repeat;opacity:.95}
.lp-form-section > *{position:relative;z-index:1}
.bubble{display:grid;background:#fff;border:1px solid #cbe7fb;border-radius:50%;box-shadow:0 12px 30px rgba(23,103,160,.14);color:var(--navy)}
.feature-strip{grid-template-columns:repeat(3,1fr);max-width:1140px;gap:0;margin:-8px auto 28px;transform:none;position:relative;z-index:3}
.feature-strip article,.feature-strip article:first-child,.feature-strip article:last-child{background:#fff;border:1px solid #d8eefa;box-shadow:var(--shadow-sm);min-height:112px}
.feature-strip article:first-child{border-radius:14px 0 0 14px}
.feature-strip article:last-child{border-radius:0 14px 14px 0}
.f-icon,.f-icon.teal,.funnel-icon,.funnel-icon.green,.funnel-icon.orange,.funnel-icon.red,.article-card-head .cat-icon,.article-card-head .cat-icon.teal,.article-card-head .cat-icon.orange,.article-card-head .cat-icon.red{border-radius:14px;background:linear-gradient(135deg,#1ba7d6,#0a4f98)}
.f-icon.teal,.funnel-icon.green,.article-card-head .cat-icon.teal{background:linear-gradient(135deg,#1fc9b5,#078c86)}
.funnel-icon.orange,.article-card-head .cat-icon.orange{background:linear-gradient(135deg,#f5a623,#e07b00)}
.funnel-icon.red,.article-card-head .cat-icon.red{background:linear-gradient(135deg,#e17055,#c0392b)}
.section{padding:42px 0}
.section[style],.cluster-section{background:#fff!important;border-top:1px solid var(--line)!important}
.section-title{text-align:center;border-left:0;padding-left:0;margin-bottom:30px}
.section-title .label{color:var(--blue);font-weight:900}
.section-title h2{color:var(--navy);font-size:clamp(23px,2.6vw,34px)}
.funnel-card,.article-card,.voice-card,details{border:1px solid #d8eefa;border-radius:14px;background:#fff;box-shadow:var(--shadow-sm)}
.funnel-card:hover,.article-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.funnel-tag,.funnel-tag.orange-tag,.funnel-tag.red-tag{border:0;border-radius:999px;background:rgba(9,169,154,.10);color:var(--teal-dark)}
.funnel-tag.orange-tag{background:rgba(245,166,35,.14);color:#9a6700}
.funnel-tag.red-tag{background:rgba(216,75,53,.10);color:#b33020}
.funnel-card h3,.article-card-head h4{color:var(--navy)}
.funnel-card p{color:var(--muted)}
.cta-link{color:var(--teal-dark)!important}
.article-card-head{background:#fff;border-bottom:1px solid var(--line)}
.article-list a{color:#1a4070}
.subsidy-table-wrap{border-radius:16px;border-color:var(--line);box-shadow:var(--shadow-sm)}
.subsidy-table-head{background:linear-gradient(90deg,#e6f6ff,#fff)}
.s-table th{background:#edf7fe;color:#21415c}
.s-table td{color:var(--ink)}
.voice-avatar,.voice-avatar.f{background:#e8f4ff;border-color:#b9dbf4;color:var(--navy)}
summary{color:var(--navy)}
summary::after{color:var(--blue)}
.final-cta{background:linear-gradient(90deg,#1ea7db,#12b9a7);color:#fff;border:0}
.final-cta h2,.final-cta p{color:#fff}
.lp-page{background:#f7fcff}
.lp-hero{background:linear-gradient(105deg,#f8fdff,#eaf8ff 60%,#d7f2ff);border-bottom:1px solid #cde8f8;text-align:center}
.lp-hero .tag,.lp-hero .tag.orange-tag,.lp-hero .tag.red-tag{border:0;border-radius:999px;background:rgba(9,169,154,.12);color:var(--teal-dark)}
.lp-hero h1{color:var(--navy)}
.lp-hero h1 em,.lp-hero h1 .red-em{color:var(--teal-dark)}
.lp-hero .lead{margin-left:auto;color:#244865}
.lp-content{max-width:860px;background:transparent;border:0;margin:0 auto;padding:48px 18px 64px}
.lp-section h2{background:linear-gradient(90deg,#edf7fe,#fff);color:var(--navy);border-left:4px solid var(--teal);border-radius:0 10px 10px 0}
.lp-step,.check-list{border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm)}
.lp-step-no{background:var(--teal)!important;border-radius:50%}
.lp-form-section{background:linear-gradient(108deg,var(--navy),#0a5596);border:0;border-radius:20px;color:#fff}
.lp-form-section h3,.lp-form-section p,.trust-list span{color:#fff}
.trust-list span::before{color:#4dd9ca}
main [style*="border-radius:12px"],main [style*="border-radius:14px"],main [style*="border-radius:18px"]{border-radius:14px!important}
main [style*="box-shadow"]{box-shadow:var(--shadow-sm)!important}
@media(max-width:1060px){
  .hero-inner{grid-template-columns:1fr}
  .feature-strip{grid-template-columns:1fr;gap:12px}
  .feature-strip article,.feature-strip article:first-child,.feature-strip article:last-child{border-radius:14px}
}
@media(max-width:640px){
  .hero{padding:30px 16px 24px}
  .hero h1{font-size:29px}
  .hero-actions .btn{width:100%;min-height:54px}
  .hero-visual{display:none}
}

/* Final asset replacement pass: brochure-style generated assets */
.generated-advisor{background-image:url("/assets/generated/advisor-brochure-transparent.png")!important}
.voice-avatar{font-size:0!important;background:url("/assets/generated/advisor-brochure-transparent.png") center bottom/contain no-repeat!important;border:0!important}
.final-cta::after{background-image:url("/assets/generated/advisor-brochure-transparent.png")!important}
.lp-form-section::after{background-image:url("/assets/generated/advisor-brochure-transparent.png")!important}
.generated-icon,.asset-icon,.f-icon,.funnel-icon,.article-card-head .cat-icon{
  display:block;
  background-image:url("/assets/generated/icon-sprite-brochure-transparent.png")!important;
  background-size:300% 300%!important;
  background-repeat:no-repeat!important;
  background-color:transparent!important;
  border:0!important;
  border-radius:0!important;
  box-shadow:none!important;
  color:transparent!important;
  overflow:hidden;
}
.generated-icon,.asset-icon{width:76px;height:76px;flex:0 0 76px}
.asset-icon.small,.article-card-head .cat-icon{width:54px;height:54px;flex:0 0 54px}
.asset-icon.inline{width:58px;height:58px;flex:0 0 58px}
.asset-icon.subsidy,.f-icon.teal,.funnel-icon.green,.article-card-head .cat-icon.teal{background-position:0% 0%!important}
.generated-icon.estimate,.asset-icon.estimate,.f-icon:not(.teal),.funnel-icon:not(.green):not(.orange):not(.red),.article-card-head .cat-icon:not(.teal):not(.orange):not(.red){background-position:50% 0%!important}
.generated-icon.consult,.asset-icon.warning,.funnel-icon.red,.article-card-head .cat-icon.red{background-position:100% 0%!important}
.generated-icon.solar,.asset-icon.backup,.funnel-icon.orange,.article-card-head .cat-icon.orange{background-position:0% 50%!important}
.asset-icon.area{background-position:50% 50%!important}
.asset-icon.company{background-position:100% 50%!important}
.asset-icon.update{background-position:0% 100%!important}
.generated-icon.house,.asset-icon.house{background-position:50% 100%!important}
.generated-icon.check,.asset-icon.check{background-position:100% 100%!important}
.brand-mark{background:url("/assets/generated/icon-sprite-brochure-transparent.png") 50% 100%/300% 300% no-repeat!important;box-shadow:none!important}
.brand-mark::before{display:none}
.bubble{display:none!important}


/* Remove low-quality advisor cutout usage */
.generated-advisor{display:none!important;background:none!important}
.voice-card{padding-left:72px!important}
.voice-avatar.quote{display:grid!important;place-items:center!important;background:#e8f4ff!important;border:2px solid #b9dbf4!important;border-radius:50%!important;color:var(--blue)!important;font-size:0!important}
.voice-avatar.quote::before{content:"“";font-size:34px;font-weight:900;line-height:1;color:var(--blue)}
.final-cta::after,.lp-form-section::after{display:none!important;background:none!important}


/* Testimonial generated avatars */
.voice-card{padding-left:92px!important}
.voice-avatar.avatar-m40,.voice-avatar.avatar-f50,.voice-avatar.avatar-m60{display:block!important;width:58px!important;height:58px!important;border:0!important;border-radius:50%!important;background-image:url("/assets/generated/testimonial-avatars-transparent.png")!important;background-size:300% 100%!important;background-repeat:no-repeat!important;background-color:transparent!important}
.voice-avatar.avatar-m40{background-position:0% 50%!important}
.voice-avatar.avatar-f50{background-position:50% 50%!important}
.voice-avatar.avatar-m60{background-position:100% 50%!important}
.voice-avatar.avatar-m40::before,.voice-avatar.avatar-f50::before,.voice-avatar.avatar-m60::before{display:none!important;content:none!important}

/* Responsive checklist banner */
.checklist-banner{display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,320px);gap:28px;align-items:center;padding:30px 34px;background:linear-gradient(108deg,#e8f7ff,#f0fff8);border:2px solid var(--teal);border-radius:18px;box-shadow:var(--shadow-sm);overflow:hidden}
.checklist-banner-copy{min-width:0}
.checklist-kicker{margin:0 0 8px;color:var(--teal-dark);font-size:12px;font-weight:900}
.checklist-banner h3{margin:0 0 10px;color:var(--navy);font-size:21px;line-height:1.45}
.checklist-banner-copy p:not(.checklist-kicker){margin:0;color:var(--muted);font-size:13px;line-height:1.8}
.checklist-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.checklist-chips span{display:inline-flex;align-items:center;min-height:30px;padding:5px 12px;background:rgba(9,169,154,.1);color:var(--teal-dark);border-radius:999px;font-size:12px;font-weight:900;white-space:normal}
.checklist-banner-action{display:grid;justify-items:center;gap:10px;text-align:center;min-width:0}
.checklist-banner-action .asset-icon{width:96px;height:96px;flex:0 0 96px}
.checklist-banner-action .btn{width:100%;max-width:300px;min-width:0}
.checklist-banner-action p{margin:0;color:var(--muted);font-size:11px;font-weight:800}
@media(max-width:760px){
  .checklist-banner{grid-template-columns:1fr;padding:22px 18px;gap:20px}
  .checklist-banner h3{font-size:19px}
  .checklist-banner-action{justify-items:stretch}
  .checklist-banner-action .asset-icon{justify-self:center;width:82px;height:82px;flex-basis:82px}
  .checklist-banner-action .btn{max-width:none}
  .checklist-chips{gap:8px}
  .checklist-chips span{font-size:12px;line-height:1.35}
}
@media(max-width:420px){
  .checklist-banner{padding:20px 14px}
  .checklist-chips{display:grid;grid-template-columns:1fr 1fr}
  .checklist-chips span{justify-content:center;text-align:center;padding:7px 8px}
}

/* Final mobile hardening: prevent CTA/article blocks from squeezing copy */
@media(max-width:980px){
  .checklist-banner,
  .feature-article-banner,
  .article-hero-visual,
  .inline-cta,
  .final-cta{
    grid-template-columns:1fr!important;
  }
  .checklist-banner{
    padding:24px 18px!important;
    gap:20px!important;
  }
  .feature-article-banner{
    gap:18px!important;
    padding:24px 18px!important;
  }
  .feature-article-banner .btn{
    width:100%!important;
    max-width:none!important;
    min-width:0!important;
    white-space:normal!important;
  }
  .checklist-banner-copy,
  .article-hero-copy,
  .inline-cta > div{
    min-width:0!important;
    width:100%!important;
  }
  .checklist-banner-action{
    justify-items:stretch!important;
    width:100%!important;
  }
  .checklist-banner-action .asset-icon{
    justify-self:center!important;
    width:84px!important;
    height:84px!important;
    flex-basis:84px!important;
  }
  .checklist-banner-action .btn,
  .inline-cta .btn{
    width:100%!important;
    max-width:none!important;
    min-width:0!important;
    white-space:normal!important;
  }
}

@media(max-width:640px){
  .article-layout{
    padding:16px 12px 40px!important;
  }
  .article-main{
    padding:22px 16px 32px!important;
    border-radius:12px!important;
  }
  .article-header h1{
    font-size:24px!important;
    line-height:1.5!important;
  }
  .article-body{
    font-size:15px!important;
  }
  .article-body h2{
    font-size:19px!important;
    line-height:1.45!important;
    padding:12px 14px!important;
  }
  .article-toc-box ol{
    padding-left:30px!important;
    padding-right:14px!important;
  }
  .article-data-box{
    overflow-x:auto!important;
  }
  .article-data-table{
    min-width:560px!important;
  }
}
