/* ─── RESET & TOKENS ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --deep:#18344F;--navy:#1E4470;--blue:#2B6CB0;--mid:#4A90C4;
  --sky:#7AB8D9;--pale:#C4DFEE;--mist:#E8F3F9;--white:#F7FBFD;
  --ink:#1B2B3A;--body:#3D5166;--light:#7A9BB5;
  --green:#15803D;--green-l:#DCFCE7;--red:#DC2626;--red-l:#FEE2E2;
  --amber:#D97706;--amber-l:#FEF3C7;
  --serif-jp:'Shippori Mincho','Hiragino Mincho ProN',serif;
  --serif-en:'Cormorant Garamond',Georgia,serif;
  --sans:'Noto Sans JP',sans-serif;
  --mono:'DM Mono',monospace;
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--white);color:var(--ink);overflow-x:clip}

/* ─── NAV ─── */
.nav{position:fixed;top:0;left:0;right:0;z-index:300;height:60px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;transition:background .4s,border-color .4s;border-bottom:1px solid transparent;transform:translateZ(0);-webkit-transform:translateZ(0)}
.nav-bg{position:absolute;inset:0;background:linear-gradient(135deg,#0F2238 0%,#1A3A5C 45%,#2660A8 100%);z-index:-1}
.nav.scrolled{background:rgba(247,251,253,.95);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-color:rgba(44,108,176,.12)}
.nav.scrolled .nav-bg{display:none}
.nav-logo{display:flex;align-items:baseline;gap:9px;text-decoration:none}
.nav-logo:hover{opacity:.75}
.nl-jp{font-family:var(--serif-jp);font-size:15px;font-weight:700;color:#F0F8FC;letter-spacing:.05em;transition:color .4s}
.nl-sep{font-family:var(--serif-en);font-size:12px;color:rgba(255,255,255,.35);transition:color .4s}
.nl-en{font-family:var(--serif-en);font-style:italic;font-size:12px;color:rgba(255,255,255,.5);transition:color .4s}
.nav.scrolled .nl-jp{color:var(--deep)}.nav.scrolled .nl-sep{color:var(--light)}.nav.scrolled .nl-en{color:var(--light)}
.nav-links{display:none;list-style:none;gap:24px}
@media(min-width:768px){.nav-links{display:flex}}
.nav-links a{font-size:12px;letter-spacing:.07em;text-decoration:none;color:rgba(255,255,255,.72);transition:color .25s}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav.scrolled .nav-links a{color:var(--body)}.nav.scrolled .nav-links a:hover,.nav.scrolled .nav-links a.active{color:var(--blue)}
.nav-burger{background:none;border:none;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:6px}
.nav-burger span{display:block;width:20px;height:1.5px;background:rgba(255,255,255,.8);border-radius:2px;transition:all .3s}
.nav.scrolled .nav-burger span{background:var(--body)}
@media(min-width:768px){.nav-burger{display:none}}
/* ハンバーガー → X 変形 */
.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
/* ドロワーオーバーレイ */
.nav-drawer-overlay{display:none;position:fixed;inset:0;background:rgba(10,20,35,.5);z-index:890;backdrop-filter:blur(3px)}
.nav-drawer-overlay.open{display:block}
/* ドロワー本体 */
.nav-drawer{position:fixed;top:0;right:0;width:260px;height:100%;background:#fff;z-index:900;box-shadow:-4px 0 24px rgba(0,0,0,.18);transform:translateX(100%);transition:transform .28s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column}
.nav-drawer.open{transform:translateX(0)}
.nav-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--pale)}
.nav-drawer-logo{font-family:var(--serif-jp);font-size:14px;font-weight:600;color:var(--deep);letter-spacing:.04em}
.nav-drawer-close{background:none;border:none;cursor:pointer;font-size:18px;color:var(--light);padding:4px 6px;transition:color .2s}
.nav-drawer-close:hover{color:var(--deep)}
.nav-drawer-list{list-style:none;padding:12px 0;flex:1}
.nav-drawer-list li button{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:14px 22px;font-size:13.5px;font-family:var(--sans);color:var(--ink);letter-spacing:.03em;transition:background .15s}
.nav-drawer-list li button:hover{background:var(--mist);color:var(--navy)}
.nav-drawer-disabled span{display:block;padding:14px 22px;font-size:13.5px;color:var(--light);letter-spacing:.03em}

/* ─── PAGE HERO subtitle ─── */
.ph-sub{font-size:13px;font-weight:300;line-height:2;color:rgba(196,228,244,.7);letter-spacing:.05em;max-width:440px;margin:0 auto}
.ph-purpose{display:inline-block;margin-top:14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:100px;padding:6px 18px;font-size:12px;color:rgba(200,232,245,.85);letter-spacing:.06em}

/* ─── TAB CONTEXT STRIP ─── */
.tab-context{font-size:11px;color:var(--light);background:var(--mist);border-bottom:1px solid var(--pale);padding:6px 24px;letter-spacing:.04em;text-align:center}

/* ─── SUMMARY VARIANTS (共通B) ─── */
/* 01: スコアサマリー */
.sum-score{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:28px}
@media(max-width:480px){.sum-score{grid-template-columns:1fr 1fr}}
.sum-score-item{background:#fff;border:1.5px solid var(--pale);border-radius:14px;padding:13px 14px;text-align:center}
.sum-score-item.hi{border-color:#BBF7D0;background:#F0FDF4}
.sum-score-item.lo{border-color:#FDE68A;background:#FFFBEB}
.ss-label{font-size:10px;color:var(--light);letter-spacing:.04em;margin-bottom:4px}
.ss-val{font-family:var(--mono);font-size:17px;font-weight:500;color:var(--deep)}
.ss-chip{font-size:10px;margin-top:3px}

/* 02: 家計ダイアグラム */
.kake-diagram{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:26px}
@media(min-width:540px){.kake-diagram{grid-template-columns:repeat(4,1fr)}}
.kd-box{border-radius:14px;padding:14px 12px;text-align:center;border:1.5px solid}
.kd-box.inc{background:linear-gradient(135deg,#EFF6FF,#DBEAFE);border-color:#93C5FD}
.kd-box.exp{background:linear-gradient(135deg,#F5F3FF,#EDE9FE);border-color:#C4B5FD}
.kd-box.sav{background:linear-gradient(135deg,#F0FDF4,#DCFCE7);border-color:#86EFAC}
.kd-box.dbt{background:linear-gradient(135deg,#FFF7ED,#FED7AA);border-color:#FDBA74}
.kd-icon{font-size:22px;margin-bottom:6px}
.kd-label{font-size:10px;color:var(--body);letter-spacing:.04em;margin-bottom:5px}
.kd-val{font-family:var(--mono);font-size:16px;font-weight:500;line-height:1.2}
.kd-box.inc .kd-val{color:#1D4ED8}
.kd-box.exp .kd-val{color:#7C3AED}
.kd-box.sav .kd-val{color:#15803D}
.kd-box.dbt .kd-val{color:#C2410C}
.kd-real{font-size:9.5px;color:var(--light);margin-top:3px}

/* 04: 借金の使い道ランキング */
.debt-usage{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.du-row{display:flex;align-items:center;gap:10px}
.du-rank{font-family:var(--serif-en);font-style:italic;font-size:18px;color:var(--pale);font-weight:300;width:28px;text-align:center;flex-shrink:0}
.du-label{font-size:13px;color:var(--body);width:210px;flex-shrink:0}
.du-bar-bg{flex:1;height:9px;background:var(--mist);border-radius:100px;overflow:hidden;min-width:60px}
@media(max-width:480px){.du-label{width:130px;font-size:11.5px}}
.du-bar{height:100%;border-radius:100px;transition:width 1s cubic-bezier(.16,1,.3,1)}
.du-val{font-family:var(--mono);font-size:11px;color:var(--light);width:44px;text-align:right;flex-shrink:0}

/* 05: 折れ線グラフ */
.trend-chart-wrap{background:#fff;border:1.5px solid var(--pale);border-radius:16px;padding:18px 16px 10px;margin-bottom:18px;overflow:hidden}
.trend-chart-title{font-size:12px;font-weight:500;color:var(--body);margin-bottom:12px;letter-spacing:.04em}
.trend-legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:8px}
.tl-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--body)}
.tl-dot{width:10px;height:3px;border-radius:2px;flex-shrink:0}

/* 前年比矢印 */
.td-up{color:var(--green);font-size:9px}
.td-dn{color:var(--red);font-size:9px}
.td-eq{color:var(--light);font-size:9px}

/* ─── 辞典モーダル ─── */
.gloss-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:10px;background:var(--mist);border:1.5px solid var(--pale);font-size:12.5px;color:var(--navy);font-family:var(--sans);cursor:pointer;transition:all .2s;letter-spacing:.04em;margin-bottom:24px}
.gloss-btn:hover{background:var(--pale);border-color:var(--mid)}
.gloss-btn svg{width:15px;height:15px;stroke:currentColor;stroke-width:1.5;fill:none}
.gloss-modal-overlay{display:none;position:fixed;inset:0;background:rgba(18,30,46,.55);z-index:800;backdrop-filter:blur(4px);align-items:center;justify-content:center;padding:20px}
.gloss-modal-overlay.open{display:flex}
.gloss-modal{background:#fff;border-radius:20px;width:100%;max-width:640px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.22)}
.gloss-modal-head{padding:18px 22px 14px;border-bottom:1px solid var(--pale);display:flex;align-items:center;gap:10px}
.gloss-modal-head h3{font-family:var(--serif-jp);font-size:16px;font-weight:600;color:var(--deep);flex:1;letter-spacing:.04em}
.gloss-search{flex:1;border:1.5px solid var(--pale);border-radius:8px;padding:7px 12px;font-size:13px;font-family:var(--sans);color:var(--ink);outline:none;transition:border-color .2s}
.gloss-search:focus{border-color:var(--mid)}
.gloss-close{background:none;border:none;cursor:pointer;padding:6px;color:var(--light);font-size:20px;line-height:1;flex-shrink:0;transition:color .2s}
.gloss-close:hover{color:var(--ink)}
.gloss-modal-body{overflow-y:auto;padding:16px 22px 22px;display:flex;flex-direction:column;gap:10px}
.gloss-modal-item{border-bottom:1px solid var(--mist);padding-bottom:10px}
.gloss-modal-item:last-child{border-bottom:none;padding-bottom:0}
.gm-term{font-family:var(--serif-jp);font-size:13px;font-weight:600;color:var(--navy);margin-bottom:3px}
.gm-def{font-size:12px;color:var(--body);line-height:1.75}
.gloss-modal-none{font-size:13px;color:var(--light);padding:12px 0}
@media(max-width:480px){
  .gloss-modal-head{flex-wrap:wrap;gap:8px}
  .gloss-modal-head h3{flex:0 0 100%;margin-bottom:0;font-size:14px}
  .gloss-search{flex:1;min-width:0}
}

/* ─── CTA改善 (⑰) ─── */
.btm-ctas{background:linear-gradient(135deg,#0F2238 0%,#1A3A5C 45%,#2660A8 100%);padding:48px 24px;text-align:center}
.btm-ai-cta{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;border-radius:14px;background:linear-gradient(135deg,#2660A8,#4A90C4);border:none;font-size:15px;font-weight:500;color:#fff;font-family:var(--sans);cursor:pointer;text-decoration:none;letter-spacing:.04em;box-shadow:0 4px 20px rgba(0,0,0,.3);transition:all .25s;margin-bottom:20px}
.btm-ai-cta:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.35)}
.btm-ai-cta svg{width:20px;height:20px;stroke:currentColor;stroke-width:1.5;fill:none}
.btm-ai-sub{font-size:11px;color:rgba(196,228,244,.5);margin-bottom:20px;letter-spacing:.04em}
.page-hero{position:relative;padding:108px 24px 72px;text-align:center;overflow:hidden}
.ph-bg{position:absolute;inset:0;z-index:-2;background:linear-gradient(168deg,#1C3F62 0%,#1E4470 28%,#2B6CB0 60%,#4A90C4 100%)}
.ph-light-1{position:absolute;inset:0;z-index:-1;background:radial-gradient(ellipse 90% 55% at 50% -5%,rgba(12,24,40,.7) 0%,transparent 60%)}
.ph-light-2{position:absolute;inset:0;z-index:-1;background:radial-gradient(ellipse 70% 50% at 8% 35%,rgba(80,152,210,.28) 0%,transparent 55%)}
.ph-light-3{position:absolute;inset:0;z-index:-1;background:radial-gradient(ellipse 55% 40% at 92% 55%,rgba(44,100,176,.22) 0%,transparent 55%)}
.ph-grain{position:absolute;inset:0;z-index:-1;opacity:.022;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:256px}
.ph-orb{position:absolute;border-radius:50%;filter:blur(72px);pointer-events:none;opacity:.18;animation:orbF linear infinite}
.ph-orb-1{width:320px;height:320px;background:radial-gradient(circle,#9ECFE8,transparent 70%);top:-60px;left:-40px;animation-duration:19s}
.ph-orb-2{width:240px;height:240px;background:radial-gradient(circle,#5BA3D0,transparent 70%);bottom:100px;right:-30px;animation-duration:15s;animation-delay:-5s}
@keyframes orbF{0%{transform:translate(0,0)}50%{transform:translate(18px,-14px)}100%{transform:translate(0,0)}}
.ph-content{position:relative}
.ph-eyebrow{font-family:var(--serif-en);font-style:italic;font-size:12px;letter-spacing:.22em;color:rgba(200,232,245,.6);margin-bottom:14px;display:block}
.ph-title{font-family:var(--serif-jp);font-weight:700;font-size:clamp(22px,5vw,40px);line-height:1.5;color:#F0F8FC;letter-spacing:.04em;margin-bottom:12px}
.ph-title em{font-style:normal;color:#C9A040}
.ph-sub{font-size:13px;font-weight:300;line-height:2;color:rgba(196,228,244,.7);letter-spacing:.05em;max-width:440px;margin:0 auto}

/* PDF UPDATE BANNER */
.pdf-banner{background:linear-gradient(135deg,rgba(21,128,61,.08),rgba(21,128,61,.04));border:1.5px solid #BBF7D0;border-radius:14px;padding:14px 18px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:24px}
.pdf-banner-icon{font-size:20px;flex-shrink:0}
.pdf-banner-text{flex:1;min-width:180px}
.pdf-banner-title{font-size:12px;font-weight:500;color:var(--green);letter-spacing:.04em;margin-bottom:3px}
.pdf-banner-note{font-size:11px;color:var(--body);line-height:1.7}
.pdf-upload-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:8px;background:var(--green);border:none;font-size:12px;color:#fff;font-family:var(--sans);cursor:pointer;transition:all .2s;letter-spacing:.04em;white-space:nowrap;flex-shrink:0}
.pdf-upload-btn:hover{background:#166534;transform:translateY(-1px)}
.pdf-upload-btn svg{width:13px;height:13px;stroke:currentColor;stroke-width:2;fill:none}
.pdf-status{font-size:11px;color:var(--light);margin-top:6px;width:100%;letter-spacing:.03em}
.pdf-status.ok{color:var(--green)}
.pdf-status.err{color:var(--red)}
#pdf-file-input{display:none}

/* ─── BREADCRUMB ─── */
.breadcrumb{max-width:960px;margin:0 auto;padding:14px 24px 0;display:flex;align-items:center;gap:6px;font-size:11px;color:var(--light);letter-spacing:.04em}
.breadcrumb a{color:var(--light);text-decoration:none;transition:color .2s}.breadcrumb a:hover{color:var(--blue)}
.bc-sep{opacity:.4}

/* ─── TAB NAV ─── */
.tab-nav{position:sticky;top:60px;z-index:200;background:rgba(247,251,253,.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--pale)}
.tab-nav-inner{max-width:960px;margin:0 auto;padding:4px 16px;display:flex;flex-wrap:wrap;gap:2px}
.tab-nav-inner::-webkit-scrollbar{display:none}
.tab-btn{flex-shrink:0;padding:13px 11px;font-family:var(--sans);font-size:12px;letter-spacing:.03em;color:var(--body);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;transition:color .2s,border-color .2s;white-space:nowrap}
.tab-btn:hover{color:var(--navy)}.tab-btn.active{color:var(--navy);border-color:var(--navy);font-weight:500}

/* ─── SECTION SHELL ─── */
.tab-section{display:none}.tab-section.active{display:block}
.section{padding:48px 24px 60px}
.section-inner{max-width:960px;margin:0 auto}
.s-eyebrow{font-family:var(--serif-en);font-style:italic;font-size:11px;letter-spacing:.22em;color:var(--mid);margin-bottom:8px;display:block}
.s-title{font-family:var(--serif-jp);font-weight:700;font-size:clamp(20px,3.5vw,27px);color:var(--deep);letter-spacing:.04em;margin-bottom:10px;line-height:1.5}
.s-lead{font-size:13.5px;font-weight:300;line-height:2.1;color:var(--body);letter-spacing:.04em;margin-bottom:32px;max-width:100%}

/* 30秒ボックス */
.quick{background:linear-gradient(135deg,var(--mist),rgba(196,223,238,.3));border:1.5px solid var(--pale);border-radius:14px;padding:18px 20px;margin-bottom:28px}
.quick-label{font-family:var(--serif-en);font-style:italic;font-size:10px;letter-spacing:.18em;color:var(--mid);margin-bottom:9px;display:block}
.quick ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.quick li{font-size:13px;color:var(--ink);line-height:1.7;padding-left:16px;position:relative}
.quick li::before{content:'—';position:absolute;left:0;color:var(--mid);font-size:10px;top:3px}

/* 出典ブロック */
.source{margin-top:32px;padding:12px 16px;border-top:1px solid var(--pale);font-size:10.5px;color:var(--light);line-height:1.9;letter-spacing:.03em}
.source a{color:var(--mid);text-decoration:none}.source a:hover{text-decoration:none}
/* ⑤ 出典・注意事項の下線を全ページで削除 */
.source *,.faq-src,.faq-src *,.src-note,.src-note *,.src-inline,.tbl-note{text-decoration:none}
.tbl-note{font-size:10.5px;color:var(--light);line-height:1.9;letter-spacing:.03em;margin-top:8px}

/* ─── TOOLTIPS ─── */
.term{display:inline;background:none;border:none;cursor:help;font-size:inherit;font-family:inherit;color:var(--blue);border-bottom:1.5px dashed var(--mid);padding:0;position:relative;line-height:inherit}
.term:focus{outline:2px solid var(--mid);outline-offset:2px;border-radius:2px}
.tip-pop{
  display:none;position:fixed;
  width:210px;background:var(--deep);color:rgba(240,248,252,.9);
  font-size:11.5px;font-weight:300;line-height:1.75;padding:10px 13px;
  border-radius:10px;z-index:9999;pointer-events:none;white-space:normal;text-align:left;
  box-shadow:0 8px 24px rgba(0,0,0,.28)
}
.tip-pop::after{content:'';position:absolute;border:5px solid transparent}
.tip-pop.tip-above::after{top:100%;left:var(--arrow-left,50%);transform:translateX(-50%);border-top-color:var(--deep)}
.tip-pop.tip-below::after{bottom:100%;left:var(--arrow-left,50%);transform:translateX(-50%);border-bottom-color:var(--deep)}
.term:hover .tip-pop,.term:focus .tip-pop,.term.tip-open .tip-pop{display:block}

/* ─── GLOSSARY MINI-DICT (section bottom) ─── */
.glossary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin-top:24px;margin-bottom:8px}
.gloss-card{background:white;border:1.5px solid var(--pale);border-radius:12px;padding:13px 14px;transition:border-color .2s}
.gloss-card:hover{border-color:var(--mid)}
.gloss-term{font-family:var(--serif-jp);font-size:13px;font-weight:600;color:var(--navy);margin-bottom:5px;display:flex;align-items:center;gap:6px}
.gloss-term::before{content:'';display:inline-block;width:6px;height:6px;border-radius:2px;background:var(--mid);flex-shrink:0}
.gloss-def{font-size:11.5px;color:var(--body);line-height:1.75;font-weight:300}

/* ─── S1: もしかて ─── */
.kake-note{font-size:11px;color:var(--light);font-style:italic;border:1px solid var(--pale);border-radius:8px;padding:8px 14px;margin-bottom:24px;letter-spacing:.03em}
.kake-cols{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:22px}
@media(min-width:640px){.kake-cols{grid-template-columns:1fr 1fr}}
.kake-card{border-radius:18px;overflow:hidden;border:1.5px solid var(--pale)}
.kake-head{padding:13px 18px;display:flex;align-items:center;gap:9px;font-family:var(--serif-jp);font-size:14px;font-weight:600;letter-spacing:.04em}
.kake-head.inc{background:linear-gradient(135deg,#0F2238,#2660A8);color:#F0F8FC}
.kake-head.exp{background:linear-gradient(135deg,#2D1B69,#5B3EBB);color:#F0F8FC}
.kake-head svg{width:17px;height:17px;stroke:currentColor;stroke-width:1.5;fill:none;flex-shrink:0}
.kake-total{padding:9px 18px;font-family:var(--mono);font-size:17px;font-weight:500;border-bottom:1px solid var(--pale)}
.kake-total.inc{color:var(--blue)}.kake-total.exp{color:#7C3AED}
.kake-total small{font-size:10px;color:var(--light);font-family:var(--sans);margin-left:5px}
.kake-row{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;border-bottom:1px solid rgba(196,223,238,.4);gap:8px}
.kake-row:last-child{border-bottom:none}
.kake-row-l{display:flex;align-items:center;gap:8px;flex:1;min-width:0}
.kake-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.kake-name{font-size:12.5px;color:var(--body);line-height:1.4}
.kake-sub{font-size:10px;color:var(--light)}
.kake-val{font-family:var(--mono);font-size:13px;color:var(--ink);flex-shrink:0}
.kake-pct{font-size:10px;color:var(--light);min-width:30px;text-align:right;flex-shrink:0}

/* summary bar (dark) */
.kake-sum{background:var(--deep);border-radius:18px;padding:22px 20px;margin-bottom:18px;position:relative;overflow:hidden}
.kake-sum::before{content:'';position:absolute;top:-40px;right:-40px;width:160px;height:160px;background:radial-gradient(circle,rgba(122,184,217,.12),transparent 70%);border-radius:50%}
.kake-sum-title{font-size:11px;letter-spacing:.1em;color:rgba(196,223,238,.45);margin-bottom:14px}
.kbar-row{margin-bottom:11px}
.kbar-row:last-child{margin-bottom:0}
.kbar-labels{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}
.kbar-name{font-size:12px;color:rgba(220,240,250,.75);letter-spacing:.04em}
.kbar-val{font-family:var(--mono);font-size:14px;color:#A8D8EE;font-weight:500}
.kbar-real{font-size:10px;color:rgba(196,223,238,.35);letter-spacing:.04em;display:block;margin-top:3px;text-align:right}
.kbar-bg{height:7px;background:rgba(255,255,255,.08);border-radius:100px;overflow:hidden}
.kbar-fill{height:100%;border-radius:100px;width:0;transition:width 1.1s cubic-bezier(.16,1,.3,1)}
.f-inc{background:linear-gradient(90deg,#34D399,#6EE7B7)}
.f-exp{background:linear-gradient(90deg,#818CF8,#A5B4FC)}
.f-sav{background:linear-gradient(90deg,#60A5FA,#93C5FD)}
.f-dbt{background:linear-gradient(90deg,#F59E0B,#FCD34D)}
.kake-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:18px}
@media(min-width:580px){.kake-metrics{grid-template-columns:repeat(4,1fr)}}
.km{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:12px;padding:13px 10px;text-align:center}
.km-icon{font-size:18px;margin-bottom:5px}
.km-label{font-size:10px;color:rgba(196,223,238,.45);letter-spacing:.05em;margin-bottom:5px}
.km-val{font-family:var(--mono);font-size:15px;font-weight:500;line-height:1.2}
.km-unit{font-size:9px;color:rgba(196,223,238,.35);margin-top:2px}
.km.i .km-val{color:#6EE7B7}.km.e .km-val{color:#C4B5FD}.km.s .km-val{color:#93C5FD}.km.d .km-val{color:#FCD34D}

/* ─── S2: 税金の使い道 ─── */

/* 市民1人あたりヒーローカード */
.per-hero{background:linear-gradient(135deg,#1E4470 0%,#2B6CB0 100%);border-radius:20px;padding:22px 22px 20px;margin-bottom:28px;color:#fff;position:relative;overflow:hidden}
.per-hero::before{content:'';position:absolute;top:-30px;right:-30px;width:160px;height:160px;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%);border-radius:50%;pointer-events:none}
.per-hero-label{font-size:11px;letter-spacing:.1em;color:rgba(255,255,255,.55);margin-bottom:14px;display:flex;align-items:center;gap:7px}
.per-hero-label svg{width:14px;height:14px;stroke:rgba(255,255,255,.55);stroke-width:1.5;fill:none;flex-shrink:0}
.per-hero-main{font-family:var(--mono);font-size:38px;font-weight:500;color:#fff;line-height:1;margin-bottom:4px;letter-spacing:-.01em}
.per-hero-sub{font-size:12px;color:rgba(255,255,255,.6);margin-bottom:18px}
.per-hero-breakdown{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:440px){.per-hero-breakdown{grid-template-columns:1fr 1fr}}
.phb-item{background:rgba(255,255,255,.09);border-radius:12px;padding:11px 12px}
.phb-num{font-family:var(--mono);font-size:16px;color:#fff;font-weight:500;line-height:1.2}
.phb-label{font-size:10px;color:rgba(255,255,255,.55);margin-top:3px;line-height:1.4}

/* ランキングカード (D-1) */
.rank-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:30px}
@media(max-width:540px){.rank-cards{grid-template-columns:1fr}}
.rank-card{border-radius:16px;padding:16px 16px 14px;border:1.5px solid var(--pale);background:#fff;position:relative;overflow:hidden}
.rank-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px}
.rank-card.r1::before{background:linear-gradient(90deg,#2B6CB0,#4A90C4)}
.rank-card.r2::before{background:linear-gradient(90deg,#4A90C4,#7AB8D9)}
.rank-card.r3::before{background:linear-gradient(90deg,#7AB8D9,#A8D8EE)}
.rank-num{font-family:var(--serif-en);font-style:italic;font-size:28px;color:var(--pale);line-height:1;margin-bottom:6px;font-weight:300}
.rank-card.r1 .rank-num{color:rgba(43,108,176,.25)}
.rank-name{font-size:13px;font-weight:500;color:var(--ink);line-height:1.45;margin-bottom:8px}
.rank-amt{font-family:var(--mono);font-size:18px;color:var(--blue);font-weight:500;line-height:1}
.rank-pct{font-size:11px;color:var(--light);margin-top:3px}
.rank-per{font-size:10px;color:var(--mid);margin-top:5px;padding-top:5px;border-top:1px solid var(--pale)}

/* ドーナツ + 棒グラフ 2カラム */
.spend-layout{display:grid;grid-template-columns:180px 1fr;gap:24px;align-items:start;margin-bottom:28px}
@media(max-width:560px){.spend-layout{grid-template-columns:1fr}}
.donut-wrap{position:relative;display:flex;flex-direction:column;align-items:center;gap:0}
.donut-canvas-wrap{position:relative;width:150px;height:150px}
.donut-canvas-wrap canvas{display:block}
.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.donut-center-num{font-family:var(--mono);font-size:20px;font-weight:500;color:var(--deep);line-height:1}
.donut-center-label{font-size:9px;color:var(--light);margin-top:2px;letter-spacing:.04em}
.donut-legend{margin-top:12px;display:flex;flex-direction:column;gap:5px;width:100%}
.dl-item{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--body)}
.dl-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}

/* 棒グラフ（1色グラデーション） */
.spend-bars{display:flex;flex-direction:column;gap:10px}
.spend-row{display:grid;grid-template-columns:1fr 52px 34px;align-items:center;gap:8px}
@media(max-width:360px){.spend-row{grid-template-columns:1fr;gap:3px}}
.spend-label{font-size:12.5px;color:var(--body);letter-spacing:.02em;line-height:1.35}
.spend-bar-wrap{display:flex;flex-direction:column;gap:3px}
.spend-bar-bg{height:8px;background:var(--mist);border-radius:100px;overflow:hidden}
.spend-bar{height:100%;border-radius:100px;width:0;transition:width 1s cubic-bezier(.16,1,.3,1)}
.spend-val{font-family:var(--mono);font-size:11.5px;color:var(--ink);text-align:right;white-space:nowrap}
.spend-pct{font-size:11px;color:var(--light);text-align:right}
.spend-per{font-size:9.5px;color:var(--mid);margin-top:1px}

/* 旧per-box（互換） */
.per-box{background:var(--amber-l);border:1.5px solid #FDE68A;border-radius:14px;padding:16px 18px;margin-bottom:26px;display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap}
.per-icon{flex-shrink:0;width:40px;height:40px;background:#FDE68A;border-radius:50%;display:flex;align-items:center;justify-content:center}
.per-title{font-size:12px;font-weight:500;color:#92400E;letter-spacing:.04em;margin-bottom:5px}
.per-vals{display:flex;gap:20px;flex-wrap:wrap}
.per-item{text-align:center}
.per-num{font-family:var(--mono);font-size:17px;color:var(--amber);font-weight:500}
.per-sub{font-size:10px;color:#92400E;margin-top:2px}

/* 1人あたり比較表 */
/* compare-genki モバイル対応 */
@media(max-width:599px){
  #compare-genki th:nth-child(n+5),#compare-genki td:nth-child(n+5){display:none}
}
@media(min-width:600px) and (max-width:767px){
  #compare-genki th:nth-child(n+7),#compare-genki td:nth-child(n+7){display:none}
}
.cmp1-table{width:100%;border-collapse:collapse}
.cmp1-table thead{background:var(--navy)}
.cmp1-table thead th{padding:9px 12px;font-size:10.5px;letter-spacing:.06em;color:rgba(240,248,252,.8);font-weight:500;text-align:right}
.cmp1-table thead th:first-child{text-align:left}
.cmp1-table tbody tr{border-bottom:1px solid var(--pale);transition:background .15s}
.cmp1-table tbody tr:last-child{border-bottom:none}
.cmp1-table tbody tr:hover{background:var(--mist)}
.cmp1-table tbody tr.hl-row{background:linear-gradient(90deg,rgba(43,108,176,.08),transparent)}
.cmp1-table td{padding:9px 12px;font-size:12px;color:var(--body);vertical-align:middle;text-align:right}
.cmp1-table td:first-child{text-align:left;font-weight:500;color:var(--ink)}
.cmp1-table td.hl-cell{color:var(--blue);font-weight:600}
.cmp1-note{font-size:10px;color:var(--light);margin-top:6px;letter-spacing:.03em;line-height:1.7}
/* インライン出典バッジ */
.src-inline{font-size:9.5px;color:var(--light);background:var(--mist);border-radius:4px;padding:1px 6px;letter-spacing:.03em;display:inline-block;margin-top:4px}

/* ─── 比較表（旧 — 互換維持） ─── */
.cmp-title{font-family:var(--serif-jp);font-size:16px;font-weight:600;color:var(--deep);margin-bottom:5px;letter-spacing:.04em}
.cmp-note{font-size:11px;color:var(--light);margin-bottom:14px;letter-spacing:.03em}
.tbl-wrap{overflow-x:scroll;border-radius:14px;border:1.5px solid var(--pale);scrollbar-width:thin;-webkit-overflow-scrolling:touch}
.tbl-wrap::-webkit-scrollbar{height:6px;display:block}
.tbl-wrap::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}
.tbl-wrap::-webkit-scrollbar-thumb{background:#aaa;border-radius:3px}
/* ⑧ 全テーブル左端列をスティッキー固定 */
.tbl-wrap table td:first-child,.tbl-wrap table th:first-child{position:sticky;left:0;z-index:1;box-shadow:2px 0 4px rgba(0,0,0,.08)}
.tbl-wrap table tbody td:first-child{background:#fff}
.tbl-wrap table thead th:first-child{z-index:2;background:var(--navy)}
/* ⑦ アクセス一覧テーブルのセル余白を縮小 */
#mv-access .tbl-wrap .cmp-tbl td,#mv-access .tbl-wrap .cmp-tbl th{padding:5px 7px;font-size:11.5px;white-space:nowrap}
table{width:100%;border-collapse:collapse;min-width:500px}
thead{background:var(--navy)}
thead th{padding:10px 13px;font-size:11px;letter-spacing:.07em;color:rgba(240,248,252,.85);font-weight:500;text-align:left}
tbody tr{border-bottom:1px solid var(--pale);transition:background .15s}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--mist)}
tbody tr.hl-row{background:linear-gradient(90deg,rgba(196,223,238,.22),transparent)}
td{padding:10px 13px;font-size:12.5px;color:var(--body);vertical-align:middle}
td.city{font-weight:500;color:var(--ink)}
td.num{font-family:var(--mono);font-size:12px;text-align:right}
td.hl-cell{color:var(--blue);font-weight:500}
.tbl-cap{font-size:10px;color:var(--light);margin-top:6px;letter-spacing:.03em}

/* CSV ボタン */
.csv-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:8px;background:var(--mist);border:1.5px solid var(--pale);font-size:12px;color:var(--body);font-family:var(--sans);cursor:pointer;transition:all .2s;letter-spacing:.04em;margin-top:10px}
.csv-btn:hover{background:var(--pale);border-color:var(--mid);color:var(--navy)}
.csv-btn svg{width:14px;height:14px;stroke:currentColor;stroke-width:1.5;fill:none;flex-shrink:0}
.csv-note{font-size:10px;color:var(--light);margin-top:5px;letter-spacing:.03em}
.csv-group{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}

/* ─── S3: 借金と貯金 ─── */
.debt-cards{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:20px}
@media(min-width:580px){.debt-cards{grid-template-columns:1fr 1fr}}
.dc{border-radius:18px;padding:20px 18px;border:1.5px solid}
.dc.sav{border-color:#BBF7D0;background:#F0FDF4}.dc.dbt{border-color:#FECACA;background:#FFF5F5}
.dc-head{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.dc-ico{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dc.sav .dc-ico{background:var(--green-l)}.dc.dbt .dc-ico{background:var(--red-l)}
.dc-ico svg{width:17px;height:17px;stroke-width:1.5;fill:none}
.dc.sav .dc-ico svg{stroke:var(--green)}.dc.dbt .dc-ico svg{stroke:var(--red)}
.dc-label{font-size:12px;color:var(--body);letter-spacing:.04em}
.dc-val{font-family:var(--mono);font-size:27px;font-weight:500;line-height:1.2;margin-bottom:3px}
.dc.sav .dc-val{color:var(--green)}.dc.dbt .dc-val{color:var(--red)}
.dc-unit{font-size:10px;color:var(--light);margin-bottom:12px}
.dc-desc{font-size:12px;color:var(--body);line-height:1.8}
.dc-per{margin-top:9px;font-size:12px;font-weight:500}
.dc.sav .dc-per{color:var(--green)}.dc.dbt .dc-per{color:var(--red)}
.cover-box{background:var(--mist);border-radius:14px;padding:16px 18px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:24px}
.cover-label{font-size:12px;color:var(--body);letter-spacing:.04em}
.cover-val{font-family:var(--mono);font-size:21px;color:var(--navy)}
.cover-note{font-size:11px;color:var(--body);line-height:1.8}
.bar-chart-wrap{margin-bottom:8px;margin-top:20px}
.bar-chart{display:flex;align-items:flex-end;gap:4px;height:130px;padding-bottom:26px;position:relative}
.bar-chart::after{content:'';position:absolute;bottom:26px;left:0;right:0;height:1px;background:var(--pale)}
.bar-group{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1;min-width:0}
.bar-pair{display:flex;gap:2px;align-items:flex-end;height:104px;width:100%}
.bcol{flex:1;border-radius:3px 3px 0 0;height:0;transition:height .9s cubic-bezier(.16,1,.3,1);min-width:0;cursor:default}
.bcol:hover{filter:brightness(1.12)}
.bcol.bd{background:linear-gradient(to top,#FECACA,#F87171)}
.bcol.bs{background:linear-gradient(to top,#BBF7D0,#4ADE80)}
.by{font-family:var(--mono);font-size:7.5px;color:var(--light);text-align:center;margin-top:2px;white-space:nowrap}
.bar-legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:7px}
.bl-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--body)}
.bl-dot{width:10px;height:10px;border-radius:2px}

/* ─── S4: 年ごとの変化 ─── */
.trend-wrap{border-radius:14px;border:1.5px solid var(--pale);margin-bottom:18px;overflow:hidden}
.trend-tbl{width:100%}
/* モバイルでは重要3列のみ表示 */
@media(max-width:599px){
  .trend-tbl th:nth-child(2),.trend-tbl td:nth-child(2),
  .trend-tbl th:nth-child(3),.trend-tbl td:nth-child(3),
  .trend-tbl th:nth-child(4),.trend-tbl td:nth-child(4){display:none}
}
.trend-tbl thead{background:var(--navy)}
.trend-tbl thead th{padding:10px 13px;font-size:11px;letter-spacing:.07em;color:rgba(240,248,252,.85);font-weight:500;text-align:right}
.trend-tbl thead th:first-child{text-align:left}
.trend-tbl tbody tr{border-bottom:1px solid var(--pale);transition:background .15s}
.trend-tbl tbody tr:last-child{border-bottom:none}
.trend-tbl tbody tr:hover{background:var(--mist)}
.trend-tbl td{padding:10px 13px;font-family:var(--mono);font-size:12px;color:var(--body);text-align:right;vertical-align:middle}
.trend-tbl td:first-child{font-family:var(--sans);font-weight:500;color:var(--ink);text-align:left;font-size:12px}
.trend-tbl td.hl{color:var(--blue);font-weight:500}
.archive-link{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border-radius:8px;border:1.5px solid var(--pale);background:white;font-size:13px;color:var(--navy);text-decoration:none;transition:all .2s;letter-spacing:.04em;margin-top:14px}
.archive-link:hover{border-color:var(--mid);background:var(--mist)}

/* ─── S5: FAQ ─── */
.faq-list{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
details.faq{border:1.5px solid var(--pale);border-radius:14px;background:white;overflow:hidden;transition:border-color .2s}
details.faq:hover{border-color:var(--mid)}
details.faq[open]{border-color:var(--blue)}
summary.fq{padding:15px 18px;cursor:pointer;font-size:14px;font-weight:500;color:var(--ink);list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px;letter-spacing:.03em;line-height:1.5}
summary.fq::-webkit-details-marker{display:none}
summary.fq::after{content:'';flex-shrink:0;width:17px;height:17px;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%237A9BB5' stroke-width='2' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") center/contain no-repeat;transition:transform .25s}
details[open] summary.fq::after{transform:rotate(180deg)}
.faq-body{padding:0 18px 16px;display:flex;flex-direction:column;gap:8px}
.faq-concl{font-size:13px;font-weight:500;color:var(--navy);padding:9px 13px;background:var(--mist);border-radius:8px;letter-spacing:.03em;line-height:1.7}
.faq-ans{font-size:13px;font-weight:300;line-height:2;color:var(--body);letter-spacing:.03em}
.faq-src{font-size:10.5px;color:var(--light);letter-spacing:.03em}

/* ─── BOTTOM CTAs ─── */
.btm-title{font-family:var(--serif-jp);font-size:17px;font-weight:600;color:#F0F8FC;letter-spacing:.05em;margin-bottom:22px}
.cta-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.cta{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;border-radius:100px;font-size:13px;font-family:var(--sans);letter-spacing:.05em;text-decoration:none;cursor:pointer;transition:all .28s;border:none}
.cta-p{background:rgba(255,255,255,.92);color:var(--navy);box-shadow:0 4px 14px rgba(0,0,0,.16)}
.cta-p:hover{background:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.cta-g{background:rgba(255,255,255,.1);color:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(8px)}
.cta-g:hover{background:rgba(255,255,255,.18);transform:translateY(-2px)}

/* ─── FOOTER ─── */
footer{background:linear-gradient(160deg,#1C3F62 0%,#1E4470 40%,#2B6CB0 100%);padding:38px 24px 26px;position:relative;overflow:hidden}
footer::before{content:'';position:absolute;inset:0;opacity:.022;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:256px;pointer-events:none}
.fi{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:26px;margin-bottom:26px;position:relative;z-index:1}
@media(min-width:640px){.fi{flex-direction:row;justify-content:space-between;align-items:flex-start}}
.fl{font-family:var(--serif-jp);font-size:15px;font-weight:700;color:rgba(240,248,252,.95);letter-spacing:.06em;margin-bottom:7px}
.ft{font-size:11px;font-weight:300;color:rgba(196,223,238,.5);line-height:1.8;margin-bottom:9px}
.fn{font-size:10px;font-weight:300;color:rgba(175,212,232,.35);line-height:1.9;max-width:300px;letter-spacing:.02em}
.footer-nav{display:flex;gap:38px;flex-wrap:wrap}
.fnc{display:flex;flex-direction:column;gap:10px}
.fnh{font-family:var(--serif-en);font-style:italic;font-size:10px;letter-spacing:.2em;color:var(--sky);opacity:.65;margin-bottom:2px}
.fnc a{font-size:12px;font-weight:300;color:rgba(196,223,238,.58);text-decoration:none;letter-spacing:.04em;transition:color .2s}
.fnc a:hover{color:rgba(240,248,252,.95)}
.fb{border-top:1px solid rgba(255,255,255,.09);padding-top:16px;max-width:880px;margin:0 auto;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;position:relative;z-index:1}
.fc{font-size:10px;font-weight:300;color:rgba(175,212,232,.32);letter-spacing:.05em}

/* ─── REVEAL ─── */
/* JS読み込み前はコンテンツを表示（js-loadedクラスがあるときだけアニメーション） */
.reveal{opacity:1;transform:none}
.js-loaded .reveal{opacity:0;transform:translateY(16px);transition:opacity .72s cubic-bezier(.16,1,.3,1),transform .72s cubic-bezier(.16,1,.3,1)}
.js-loaded .reveal.in{opacity:1;transform:none}
.rd1{transition-delay:.08s}.rd2{transition-delay:.17s}.rd3{transition-delay:.26s}
@media(prefers-reduced-motion:reduce){
  .js-loaded .reveal,.kbar-fill,.bcol,.spend-bar{transition:none!important;opacity:1!important;transform:none!important}
  .ph-orb{animation:none!important}
}
/* ─── GENKI SECTION ─── */
.genki-hero{text-align:center;padding:36px 0 28px;border-bottom:1px solid var(--pale);margin-bottom:36px}
.genki-label{font-family:var(--serif-en);font-style:italic;font-size:11px;letter-spacing:.22em;color:var(--mid);margin-bottom:12px;display:block}
.genki-face{font-size:clamp(56px,12vw,88px);line-height:1;margin-bottom:10px;display:block;filter:drop-shadow(0 4px 12px rgba(0,0,0,.08))}
.genki-verdict{font-family:var(--serif-jp);font-size:clamp(22px,4vw,32px);font-weight:700;color:var(--deep);letter-spacing:.05em;margin-bottom:6px}
.genki-sub{font-size:12.5px;color:var(--light);letter-spacing:.05em}
.genki-score-total{display:inline-flex;align-items:baseline;gap:4px;margin:14px 0 0}
.genki-score-num{font-family:var(--mono);font-size:clamp(48px,10vw,72px);font-weight:500;color:var(--navy);line-height:1}
.genki-score-max{font-family:var(--mono);font-size:16px;color:var(--light);margin-left:2px}
.genki-year{font-size:11px;color:var(--light);letter-spacing:.06em;margin-top:4px}

/* ゲージペア */
.genki-gauges{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px}
@media(max-width:560px){.genki-gauges{grid-template-columns:1fr}}
.gg-card{background:#fff;border:1.5px solid var(--pale);border-radius:18px;padding:22px 20px;text-align:center;position:relative;overflow:hidden}
.gg-card::before{content:'';position:absolute;inset:0;opacity:.04;pointer-events:none}
.gg-card.now::before{background:var(--blue)}
.gg-card.future::before{background:var(--green)}
.gg-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:10px;letter-spacing:.08em;font-weight:500;margin-bottom:12px}
.gg-badge.now{background:rgba(43,108,176,.1);color:var(--navy)}
.gg-badge.future{background:rgba(21,128,61,.1);color:var(--green)}
.gg-face{font-size:32px;margin-bottom:6px;display:block}
.gg-title{font-family:var(--serif-jp);font-size:15px;font-weight:600;color:var(--deep);margin-bottom:14px}
.gg-score{font-family:var(--mono);font-size:40px;font-weight:500;line-height:1;margin-bottom:12px}
.gg-score.now{color:var(--navy)}
.gg-score.future{color:var(--green)}
.gg-arc-wrap{position:relative;width:110px;height:62px;margin:0 auto 10px}
.gg-arc-svg{width:110px;height:62px}
.gg-arc-label{position:absolute;bottom:-2px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:22px;font-weight:500;color:var(--deep)}
.gg-metrics{display:flex;flex-direction:column;gap:7px;margin-top:14px;text-align:left}
.gm-row{display:flex;align-items:center;gap:8px;font-size:12px}
.gm-name{flex:1;color:var(--body);letter-spacing:.03em}
.gm-bar-bg{flex:2;height:5px;background:var(--mist);border-radius:3px;overflow:hidden}
.gm-bar-fill{height:100%;border-radius:3px;transition:width 1.2s cubic-bezier(.16,1,.3,1)}
.gm-val{font-family:var(--mono);font-size:11px;color:var(--light);min-width:28px;text-align:right}

/* 前年比バッジ */
.genki-compare{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:28px;flex-wrap:wrap}
.gc-item{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:100px;font-size:12px;font-weight:500;letter-spacing:.04em}
.gc-up{background:#DCFCE7;color:#15803D}
.gc-down{background:#FEE2E2;color:#DC2626}
.gc-flat{background:var(--mist);color:var(--body)}
.gc-arrow{font-size:14px}

/* 指標カード群 */
.genki-indicators{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-bottom:28px}
.gi-card{background:#fff;border:1.5px solid var(--pale);border-radius:14px;padding:16px 18px;transition:border-color .2s}
.gi-card:hover{border-color:var(--mid)}
.gi-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.gi-name{font-size:12.5px;font-weight:500;color:var(--deep);letter-spacing:.03em;line-height:1.4}
.gi-score-chip{font-family:var(--mono);font-size:13px;font-weight:400;padding:2px 9px;border-radius:6px;white-space:nowrap}
.chip-hi2{background:#0D9488;color:#fff}
.chip-hi{background:#BAE6FD;color:#0C4A6E}
.chip-mid{background:#FEF3C7;color:#92400E}
.chip-lo{background:#FEE2E2;color:#DC2626}
/* 財政ページ専用chip（色を上書きしない） */
.chip-fin-hi{background:#DCFCE7;color:#15803D}
.chip-fin-hi2{background:#D1FAE5;color:#065F46}
.gi-val{font-family:var(--mono);font-size:20px;font-weight:500;color:var(--navy);margin-bottom:4px}
.gi-bar-bg{height:5px;background:var(--mist);border-radius:3px;overflow:hidden;margin-bottom:6px}
.gi-bar-fill{height:100%;border-radius:3px;transition:width 1.2s cubic-bezier(.16,1,.3,1)}
.gi-desc{font-size:11px;color:var(--light);line-height:1.7;letter-spacing:.03em}
.gi-why{font-size:11px;color:var(--body);line-height:1.65;margin-top:5px;padding-top:5px;border-top:1px solid var(--mist)}

/* 解説ボックス */
.genki-note{background:linear-gradient(135deg,var(--mist),rgba(196,223,238,.3));border:1.5px solid var(--pale);border-radius:14px;padding:18px 20px;margin-bottom:24px;font-size:12.5px;color:var(--body);line-height:1.9;letter-spacing:.03em}
.genki-note strong{color:var(--deep)}


/* ══════════════════════════════════════
   PAGE ROUTER
══════════════════════════════════════ */
.page{display:none}
.page.active{display:block}

/* ══════════════════════════════════════
   HERO (トップページ)
══════════════════════════════════════ */
.hero{position:relative;width:100%;height:min(88vh,700px);height:min(88svh,700px);min-height:520px;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 18% 18%,rgba(74,144,196,.38) 0%,transparent 58%),radial-gradient(ellipse 60% 50% at 88% 78%,rgba(44,108,176,.28) 0%,transparent 55%),radial-gradient(ellipse 100% 80% at 50% 115%,rgba(24,52,79,.85) 0%,transparent 52%),linear-gradient(168deg,#1C3F62 0%,#1E4470 28%,#2B6CB0 60%,#4A90C4 100%);pointer-events:none}
.hero-shimmer-1,.hero-shimmer-2,.hero-shimmer-3{position:absolute;border-radius:50%;filter:blur(80px);opacity:.18;animation:drift linear infinite;pointer-events:none}
.hero-shimmer-1{width:500px;height:500px;background:radial-gradient(circle,#7AB8D9 0%,transparent 70%);top:-10%;left:-5%;animation-duration:22s}
.hero-shimmer-2{width:360px;height:360px;background:radial-gradient(circle,#5BA3D0 0%,transparent 70%);bottom:10%;right:-5%;animation-duration:18s;animation-delay:-6s}
.hero-shimmer-3{width:240px;height:240px;background:radial-gradient(circle,#A0CEE5 0%,transparent 70%);top:40%;left:55%;animation-duration:14s;animation-delay:-3s}
@keyframes drift{0%{transform:translate(0,0) scale(1)}33%{transform:translate(28px,-18px) scale(1.05)}66%{transform:translate(-18px,14px) scale(.97)}100%{transform:translate(0,0) scale(1)}}
.hero-grain{position:absolute;inset:0;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:256px 256px;pointer-events:none}
.hero-content{position:relative;z-index:10;text-align:center;padding:0 24px;max-width:720px;width:100%}
.hero-eyebrow{font-family:var(--serif-en);font-style:italic;font-size:clamp(12px,2vw,13px);letter-spacing:.22em;color:rgba(196,223,238,.7);margin-bottom:14px;display:block;opacity:0;transform:translateY(12px);animation:fadeUp .9s cubic-bezier(.16,1,.3,1) .3s forwards}
.hero-title{font-family:var(--serif-jp);font-weight:700;font-size:clamp(26px,5.5vw,50px);line-height:1.45;color:#F0F8FC;letter-spacing:.04em;margin-bottom:16px;opacity:0;transform:translateY(22px);animation:fadeUp 1.1s cubic-bezier(.16,1,.3,1) .55s forwards}
.hero-title em{font-style:normal;color:#A8D8EE}
.hero-sub{font-size:clamp(13px,2.2vw,14px);font-weight:300;line-height:2;color:rgba(200,228,244,.78);letter-spacing:.05em;margin-bottom:36px;opacity:0;transform:translateY(14px);animation:fadeUp 1s cubic-bezier(.16,1,.3,1) .85s forwards}
.hero-sub small{font-size:11px;opacity:.55;letter-spacing:.04em;display:block;margin-top:8px}
.hero-entries{display:flex;flex-direction:column;gap:10px;align-items:center;opacity:0;transform:translateY(14px);animation:fadeUp 1s cubic-bezier(.16,1,.3,1) 1.1s forwards}
@media(min-width:560px){.hero-entries{flex-direction:row;justify-content:center;flex-wrap:wrap}}
.entry-pill{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:100px;font-size:13px;font-weight:400;letter-spacing:.06em;text-decoration:none;transition:all .35s cubic-bezier(.16,1,.3,1);white-space:nowrap;cursor:pointer;border:none}
.entry-pill-primary{background:rgba(255,255,255,.1);color:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.entry-pill-primary:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.45);transform:translateY(-2px)}
.entry-pill-ghost{background:rgba(255,255,255,.1);color:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.entry-pill-ghost:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.45);transform:translateY(-2px)}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:10;display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:fadeUp 1s ease 1.8s forwards}
.hero-scroll-text{font-family:var(--serif-en);font-style:italic;font-size:10px;letter-spacing:.22em;color:rgba(196,223,238,.45)}
.hero-scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(196,223,238,.45),transparent);animation:scrollPulse 2.4s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{transform:scaleY(1);opacity:.5}50%{transform:scaleY(1.2);opacity:1}}
.hero-wave{position:absolute;bottom:-2px;left:0;right:0;height:130px;overflow:hidden;pointer-events:none}
.hero-wave svg{width:100%;height:100%;display:block}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{to{opacity:1}}
@media(prefers-reduced-motion:reduce){.hero-eyebrow,.hero-title,.hero-sub,.hero-entries,.hero-scroll{animation:none!important;opacity:1!important;transform:none!important}.hero-shimmer-1,.hero-shimmer-2,.hero-shimmer-3,.hero-scroll-line{animation:none!important}}

/* ══════════════════════════════════════
   TEASER
══════════════════════════════════════ */
.teaser{padding:72px 32px 80px;background:var(--white);text-align:center}
.teaser-inner{max-width:560px;margin:0 auto}
.teaser-label{display:inline-block;font-family:var(--serif-en);font-style:italic;font-size:12px;letter-spacing:.22em;color:var(--mid);margin-bottom:18px}
.teaser-title{font-family:var(--serif-jp);font-size:clamp(20px,4vw,28px);font-weight:600;line-height:1.85;color:var(--deep);letter-spacing:.05em;margin-bottom:20px;overflow-wrap:break-word;word-break:keep-all}
.teaser-body{font-size:14px;font-weight:300;line-height:2.2;color:var(--body);letter-spacing:.04em;margin-bottom:40px;overflow-wrap:break-word;word-break:keep-all}
.teaser-divider{width:1px;height:40px;background:linear-gradient(to bottom,var(--pale),transparent);margin:0 auto 40px}
.feature-grid{display:grid;grid-template-columns:1fr;gap:2px;max-width:620px;margin:0 auto;background:var(--pale);border-radius:22px;overflow:hidden;box-shadow:0 4px 32px rgba(44,108,176,.08)}
@media(min-width:620px){.feature-grid{grid-template-columns:repeat(3,1fr)}}
.feature-item{background:var(--white);padding:30px 20px 26px;text-decoration:none;color:var(--ink);transition:background .28s;display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;cursor:pointer}
.feature-item:hover{background:var(--mist)}
.feature-num{font-family:var(--serif-en);font-size:11px;letter-spacing:.18em;color:var(--mid)}
.feature-icon-wrap{width:48px;height:48px;border-radius:14px;background:var(--mist);display:flex;align-items:center;justify-content:center;transition:background .28s,transform .28s}
.feature-icon-wrap svg{width:22px;height:22px;stroke:var(--navy);stroke-width:1.5;fill:none;transition:stroke .28s}
.feature-item:hover .feature-icon-wrap{background:var(--pale);transform:scale(1.06)}
.feature-item:hover .feature-icon-wrap svg{stroke:var(--blue)}
.feature-name{font-family:var(--serif-jp);font-size:14px;font-weight:600;color:var(--deep);letter-spacing:.07em;line-height:1.5}
.feature-desc{font-size:11.5px;font-weight:300;line-height:1.85;color:var(--body);letter-spacing:.03em}
.feature-arrow{font-size:11px;color:var(--mid);margin-top:auto;letter-spacing:.12em;transition:transform .22s}
.feature-item:hover .feature-arrow{transform:translateX(5px)}

/* ══════════════════════════════════════
   NAV — minnano-style overrides for top page
══════════════════════════════════════ */
.nav-links a.active-page{color:white;font-weight:500}
.nav.scrolled .nav-links a.active-page{color:var(--blue)}

/* ── minnano footer classes ── */
.footer-inner{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:28px;margin-bottom:28px;position:relative;z-index:1}
@media(min-width:640px){.footer-inner{flex-direction:row;justify-content:space-between;align-items:flex-start}}
.footer-logo{font-family:var(--serif-jp);font-size:16px;font-weight:700;color:rgba(240,248,252,.95);letter-spacing:.06em;margin-bottom:8px}
.footer-tagline{font-size:11px;font-weight:300;color:rgba(196,223,238,.55);letter-spacing:.04em;line-height:1.8;margin-bottom:12px}
.footer-notice{font-size:10px;font-weight:300;color:rgba(175,212,232,.38);line-height:1.95;max-width:310px;letter-spacing:.02em}
.footer-nav{display:flex;gap:44px;flex-wrap:wrap}
.footer-nav-col{display:flex;flex-direction:column;gap:11px}
.footer-nav-heading{font-family:var(--serif-en);font-style:italic;font-size:10px;letter-spacing:.2em;color:var(--sky);margin-bottom:4px;opacity:.7}
.footer-nav-col a{font-size:12px;font-weight:300;color:rgba(196,223,238,.6);text-decoration:none;letter-spacing:.04em;transition:color .2s}
.footer-nav-col a:hover{color:rgba(240,248,252,.95)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:18px;max-width:880px;margin:0 auto;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;position:relative;z-index:1}
.footer-copy{font-size:10px;font-weight:300;color:rgba(175,212,232,.35);letter-spacing:.05em}

/* ── BACK BUTTON ── */
.back-btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:rgba(200,232,245,.6);letter-spacing:.04em;cursor:pointer;background:none;border:none;padding:4px 0;transition:color .2s}
.back-btn:hover{color:rgba(200,232,245,.95)}
.back-btn svg{width:14px;height:14px;stroke:currentColor;stroke-width:1.5;fill:none}

/* ── ゴールド強調 + financeセクション明色化 ── */
:root{--gold:#B8882A;--gold-lt:#C9A040}
#page-finance .faq-concl strong{color:var(--deep)}
#page-finance .kake-sum{background:linear-gradient(135deg,#1C3F62 0%,#2B6CB0 100%)}
#page-finance .section{background:#F5F9FC}
#page-finance .per-hero{background:linear-gradient(135deg,#1C3F62 0%,#2B6CB0 100%)}

/* ════════════════════════════════════════
   移住ガイド — 専用CSS
════════════════════════════════════════ */
/* ─── Breadcrumb (移住) ─── */
.bc{max-width:1040px;margin:0 auto;padding:14px 24px 0;display:flex;align-items:center;gap:6px;font-size:11px;color:var(--light);letter-spacing:.04em;flex-wrap:wrap}
.bc button{background:none;border:none;cursor:pointer;color:var(--light);font-size:11px;font-family:var(--sans);padding:0;transition:color .2s}
.bc button:hover{color:var(--blue)}
.bc-sep{opacity:.4;font-size:10px}
/* ─── Section shell (移住) ─── */
.sec{padding:52px 24px 64px}.sec-inner{max-width:1040px;margin:0 auto}
.sec.bg-mist{background:var(--mist)}.sec.bg-dark{background:var(--deep)}.sec.bg-white{background:#fff}
.s-ey{font-family:var(--serif-en);font-style:italic;font-size:11px;letter-spacing:.22em;color:var(--mid);margin-bottom:8px;display:block}
.divider{height:1px;background:var(--pale);margin:36px 0}
.src-note{font-size:10px;color:var(--light);margin-top:8px;padding-top:8px;border-top:1px solid var(--pale);line-height:1.85}
/* ─── 非公式バナー ─── */
.unofficial{background:rgba(43,108,176,.05);border:1.5px solid rgba(43,108,176,.18);border-radius:10px;padding:11px 16px;font-size:11px;color:var(--body);line-height:1.85;letter-spacing:.03em;display:flex;gap:10px;align-items:flex-start;margin-bottom:24px}
.unofficial::before{content:'ℹ';font-size:14px;color:var(--mid);flex-shrink:0;margin-top:1px}
/* ─── サブナビ ─── */
.move-tabnav{position:sticky;top:60px;z-index:200;background:rgba(247,251,253,.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--pale)}
.move-tabnav-inner{max-width:960px;margin:0 auto;padding:4px 12px;display:flex;flex-wrap:wrap;gap:0}
.move-tabnav-inner::-webkit-scrollbar{display:none}
@media(min-width:960px){.move-tabnav-inner{padding:4px 24px}}
.move-tab-btn{flex-shrink:0;padding:10px 10px;font-family:var(--sans);font-size:11.5px;letter-spacing:.03em;color:var(--body);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;transition:color .2s,border-color .2s;white-space:nowrap}
.move-tab-btn:hover{color:var(--navy)}.move-tab-btn.active{color:var(--navy);border-color:var(--navy);font-weight:500}
.move-breadcrumb{max-width:960px;margin:0 auto;padding:14px 24px 0;display:flex;align-items:center;gap:6px;font-size:11px;color:var(--light);letter-spacing:.04em}
.move-breadcrumb a,.move-breadcrumb button{color:var(--light);text-decoration:none;background:none;border:none;cursor:pointer;font-size:11px;font-family:var(--sans);padding:0;transition:color .2s}
.move-breadcrumb a:hover,.move-breadcrumb button:hover{color:var(--blue)}
/* ─── mv-page SPA ─── */
.mv-page{display:none}.mv-page.active{display:block}
/* ─── ページヒーロー (移住) ─── */
.ph{position:relative;padding:108px 24px 68px;text-align:center;overflow:hidden}
.ph-l1{position:absolute;inset:0;z-index:-1;background:radial-gradient(ellipse 90% 55% at 50% -5%,rgba(12,24,40,.7) 0%,transparent 60%)}
.ph-l2{position:absolute;inset:0;z-index:-1;background:radial-gradient(ellipse 70% 50% at 8% 35%,rgba(80,152,210,.28) 0%,transparent 55%)}
.ph-orb1{width:320px;height:320px;background:radial-gradient(circle,#9ECFE8,transparent 70%);top:-60px;left:-40px;animation-duration:19s}
.ph-orb2{width:240px;height:240px;background:radial-gradient(circle,#5BA3D0,transparent 70%);bottom:100px;right:-30px;animation-duration:15s;animation-delay:-5s}
.ph-content{position:relative}
.ph-eyebrow{font-family:var(--serif-en);font-style:italic;font-size:12px;letter-spacing:.22em;color:rgba(200,232,245,.6);margin-bottom:14px;display:block}
.ph-title{font-family:var(--serif-jp);font-weight:700;font-size:clamp(21px,4.5vw,36px);line-height:1.6;color:#F0F8FC;letter-spacing:.04em;margin-bottom:14px}
.ph-title em{font-style:normal;color:#C9A040}
.ph-lead{font-size:13px;font-weight:300;line-height:2.1;color:rgba(196,228,244,.72);letter-spacing:.05em;max-width:480px;margin:0 auto 22px}
.ph-ctas{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.ph-cta{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border-radius:100px;font-size:12.5px;letter-spacing:.04em;cursor:pointer;transition:all .2s;white-space:nowrap;font-family:var(--sans);border:1.5px solid rgba(255,255,255,.3);color:#F0F8FC;background:rgba(255,255,255,.12)}
.ph-cta:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.5)}
.ph-badge{display:inline-flex;align-items:center;gap:7px;margin-top:18px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);border-radius:100px;padding:6px 16px;font-size:11px;color:rgba(196,228,244,.65);letter-spacing:.05em}
/* ─── 年齢ピラミッド ─── */
.age-rows{display:flex;flex-direction:column;gap:10px}
.age-row{display:grid;grid-template-columns:80px 1fr;gap:10px;align-items:center}
@media(max-width:480px){.age-row{grid-template-columns:60px 1fr}}
.age-label{font-size:12px;color:var(--body);text-align:right}.age-label.hl{color:var(--navy);font-weight:600}
.age-stack{display:flex;height:26px;border-radius:5px;overflow:hidden}
.age-seg{height:100%;transition:width 1.2s cubic-bezier(.16,1,.3,1);position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.age-seg-label{font-size:10px;font-weight:500;color:rgba(255,255,255,.9);white-space:nowrap;pointer-events:none}
.age-note{font-size:10.5px;color:var(--light)}
/* ─── レーダー ─── */
.radar-wrap{display:flex;justify-content:center;margin:16px 0 8px}
/* ─── 声カード ─── */
.voice-card{background:#fff;border:1.5px solid var(--pale);border-radius:16px;padding:20px 18px;display:flex;flex-direction:column;gap:10px}
.vc-head{display:flex;align-items:center;gap:12px}
.vc-avatar{width:42px;height:42px;border-radius:50%;background:var(--mist);border:2px solid var(--pale);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.vc-meta{flex:1}.vc-name{font-size:12.5px;font-weight:500;color:var(--ink);letter-spacing:.04em}
.vc-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}
.vc-tag{font-size:10px;padding:2px 8px;border-radius:100px;background:var(--mist);color:var(--body)}
.vc-good{background:var(--green-l);border-radius:10px;padding:10px 14px}
.vc-bad{background:var(--amber-l);border-radius:10px;padding:10px 14px}
.vc-section-label{font-size:10px;font-weight:600;letter-spacing:.06em;margin-bottom:5px}
.vc-good .vc-section-label{color:var(--green)}.vc-bad .vc-section-label{color:var(--amber)}
.vc-text{font-size:12.5px;color:var(--body);line-height:1.85}
/* ─── チャートラッパー ─── */
.chart-wrap{background:#fff;border:1.5px solid var(--pale);border-radius:16px;padding:20px 16px 12px;margin-bottom:18px;overflow:hidden}
.chart-title{font-size:12px;font-weight:500;color:var(--body);margin-bottom:14px;letter-spacing:.04em;display:flex;justify-content:space-between;align-items:center}
.chart-legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:10px}
.cl-item{display:flex;align-items:center;gap:5px;font-size:10.5px;color:var(--body)}
.cl-dot{width:10px;height:3px;border-radius:2px}
.access-canvas-wrap{background:#fff;border:1.5px solid var(--pale);border-radius:16px;padding:20px;display:flex;justify-content:center;margin-bottom:20px}
.station-selector{margin:0 0 20px}
.station-selector-label{font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--light);text-transform:uppercase;margin-bottom:8px}
.station-btns{display:flex;gap:8px;flex-wrap:wrap}
.station-btn{flex:1;min-width:72px;padding:10px 6px;border:1.5px solid var(--pale);border-radius:10px;background:#fff;color:var(--body);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;font-family:var(--sans)}
.station-btn:hover{border-color:#2B6CB0;color:#2B6CB0}
.station-btn.active{background:#1A3A5C;color:#fff;border-color:#1A3A5C}
.station-note-badge{display:inline-block;background:var(--amber-l,#FFF8E6);color:#92400E;font-size:10px;font-weight:700;padding:2px 8px;border-radius:100px;margin-left:8px;vertical-align:middle}
/* ─── Reveal 互換 ─── */
.reveal.visible{opacity:1;transform:none}
/* ─── 前後ナビ（新規） ─── */
.move-nav-btns{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;max-width:1040px;margin:0 auto;gap:12px;border-top:1px solid var(--pale)}
.move-nav-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border-radius:100px;font-size:12.5px;letter-spacing:.04em;cursor:pointer;transition:all .2s;font-family:var(--sans);border:1.5px solid var(--pale);color:var(--body);background:#fff}
.move-nav-btn:hover{border-color:var(--mid);color:var(--navy);background:var(--mist)}
.move-nav-btn.primary{background:var(--navy);color:#fff;border-color:var(--navy)}
.move-nav-btn.primary:hover{background:var(--blue);border-color:var(--blue)}
.move-nav-spacer{flex:1}
/* ─── 相談CTA（新規） ─── */
.consult-cta{background:linear-gradient(135deg,#0F2238 0%,#1A3A5C 45%,#2660A8 100%);border-radius:18px;padding:28px 24px;text-align:center;margin:32px 0}
.consult-cta-title{font-family:var(--serif-jp);font-size:16px;font-weight:600;color:#F0F8FC;margin-bottom:8px;letter-spacing:.04em}
.consult-cta-desc{font-size:12.5px;color:rgba(196,228,244,.7);line-height:1.9;margin-bottom:18px}
.consult-cta-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:100px;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.3);color:#F0F8FC;font-size:13px;font-family:var(--sans);cursor:pointer;transition:all .2s;text-decoration:none}
.consult-cta-btn:hover{background:rgba(255,255,255,.25)}
/* ─── チェックリスト（新規） ─── */
.move-checklist{background:linear-gradient(135deg,var(--mist),rgba(196,223,238,.4));border:1.5px solid var(--pale);border-radius:16px;padding:22px;margin-bottom:28px}
.mc-title{font-family:var(--serif-jp);font-size:15px;font-weight:600;color:var(--deep);margin-bottom:4px;letter-spacing:.04em}
.mc-sub{font-size:11.5px;color:var(--body);margin-bottom:16px;line-height:1.7}
.mc-items{display:flex;flex-direction:column;gap:6px}
.mc-item{display:flex;align-items:flex-start;gap:10px;cursor:pointer;padding:8px 10px;border-radius:8px;transition:background .15s;user-select:none}
.mc-item:hover{background:rgba(43,108,176,.06)}
.mc-check{width:18px;height:18px;border-radius:4px;border:1.5px solid var(--pale);background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:11px;transition:all .2s;margin-top:1px}
.mc-item.checked .mc-check{background:var(--green);border-color:var(--green);color:#fff}
.mc-label{font-size:12.5px;color:var(--ink);line-height:1.6}
.mc-item.checked .mc-label{color:var(--light)}
.mc-progress{margin-top:14px;display:flex;align-items:center;gap:10px;padding-top:12px;border-top:1px solid rgba(196,223,238,.5)}
.mc-progress-bar-bg{flex:1;height:5px;background:var(--pale);border-radius:100px;overflow:hidden}
.mc-progress-bar{height:100%;background:linear-gradient(90deg,#15803D,#34D399);border-radius:100px;width:0;transition:width .4s ease}
.mc-progress-text{font-size:11px;color:var(--body);white-space:nowrap;font-family:var(--mono)}
/* ─── 人口スコアカード ─── */
.pop-score-card{background:linear-gradient(135deg,var(--mist),rgba(196,223,238,.25));border:1.5px solid var(--pale);border-radius:18px;padding:22px 20px;margin-bottom:32px}
.psc-header{display:flex;align-items:baseline;flex-wrap:wrap;gap:6px 12px;margin-bottom:18px;border-bottom:1px solid var(--pale);padding-bottom:12px}
.psc-label{font-size:10px;font-weight:700;letter-spacing:.12em;color:var(--mid);font-family:var(--sans)}
.psc-title{font-family:var(--serif-jp);font-size:16px;font-weight:700;color:var(--deep)}
.psc-period{font-size:10.5px;color:var(--light);margin-left:auto}
.psc-hero{display:flex;align-items:center;gap:20px;margin-bottom:22px}
.psc-ring-wrap{position:relative;width:110px;height:110px;flex-shrink:0}
.psc-ring-svg{width:110px;height:110px}
.psc-ring-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0}
.psc-ring-num{font-size:26px;font-weight:700;font-family:var(--mono);color:var(--deep);line-height:1}
.psc-ring-unit{font-size:10px;color:var(--light)}
.psc-hero-text{flex:1}
.psc-face{font-size:28px;line-height:1;margin-bottom:4px}
.psc-verdict{font-family:var(--serif-jp);font-size:16px;font-weight:700;color:var(--deep);margin-bottom:4px}
.psc-note{font-size:11px;color:var(--light);line-height:1.6}
.psc-indicators{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}
@media(max-width:560px){.psc-indicators{grid-template-columns:1fr}}
.psc-ind-card{background:#fff;border:1px solid var(--pale);border-radius:12px;padding:12px 10px;text-align:center}
.psc-ind-icon{font-size:18px;margin-bottom:3px}
.psc-ind-name{font-family:var(--serif-jp);font-size:13px;font-weight:600;color:var(--deep);margin-bottom:1px}
.psc-ind-sub{font-size:9.5px;color:var(--light);margin-bottom:6px;line-height:1.4}
.psc-arc-wrap{position:relative;width:90px;margin:0 auto 4px}
.psc-arc-svg{width:90px;height:52px;display:block}
.psc-arc-num{position:absolute;bottom:0;left:50%;transform:translateX(-50%);font-size:16px;font-weight:700;font-family:var(--mono);color:var(--deep)}
.psc-ind-val{font-size:11px;font-weight:600;color:var(--navy);margin:4px 0 3px}
.psc-ind-desc{font-size:10.5px;color:var(--body);line-height:1.55;text-align:left}
.psc-details{margin:4px 0 14px;border:1px solid var(--pale);border-radius:12px;overflow:hidden}
.psc-details summary{padding:12px 16px;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--serif-jp);color:var(--deep);background:var(--mist);display:flex;justify-content:space-between;align-items:center;list-style:none;user-select:none}
.psc-details-body{padding:14px 16px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.psc-criteria-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:14px}
@media(max-width:500px){.psc-criteria-grid{grid-template-columns:repeat(3,1fr)}}
.psc-table{width:100%;border-collapse:collapse;font-size:11.5px;margin-bottom:4px}
.psc-table thead tr{background:var(--mist)}
.psc-table th{padding:7px 8px;font-weight:500;color:var(--deep);border-bottom:2px solid var(--pale);text-align:left;white-space:nowrap}
.psc-table td{padding:7px 8px;border-bottom:1px solid var(--mist);color:var(--body);vertical-align:middle}
.psc-td-val{font-family:var(--mono);font-weight:600;color:var(--navy);text-align:right}
.psc-compare-head{font-family:var(--serif-jp);font-size:14px;font-weight:600;color:var(--deep);margin:16px 0 4px}
.psc-compare-table{width:100%;border-collapse:collapse;font-size:12px;min-width:380px}
.psc-compare-table thead tr{background:var(--navy)}
.psc-compare-table th{padding:8px 8px;font-weight:500;color:rgba(240,248,252,.85);border-bottom:2px solid var(--pale);text-align:center;white-space:nowrap;line-height:1.4}
.psc-compare-table th span{font-size:8.5px;opacity:.55;font-weight:400;display:block}
.psc-compare-table td{padding:7px 8px;border-bottom:1px solid var(--mist);text-align:center;vertical-align:middle}
.psc-compare-table tr.psc-hl{background:rgba(43,108,176,.07)}
.psc-compare-table tr.psc-hl td{font-weight:600;color:var(--deep)}
/* ─── 読み解きブロック ─── */
.insight-block{display:flex;flex-direction:column;gap:16px;margin-bottom:28px}
.insight-row{display:flex;gap:14px;align-items:flex-start;padding:14px 16px;background:linear-gradient(135deg,var(--mist),rgba(196,223,238,.18));border:1px solid var(--pale);border-radius:12px}
.insight-icon{font-size:20px;flex-shrink:0;margin-top:1px}
.insight-text{font-size:13px;line-height:1.85;color:var(--body);letter-spacing:.03em}
.insight-text strong{color:var(--deep);display:block;margin-bottom:4px;font-size:13.5px}
/* ─── 評価ブロック ─── */
.eval-block{background:linear-gradient(135deg,var(--mist),rgba(196,223,238,.25));border:1.5px solid var(--pale);border-radius:18px;padding:22px 20px;margin-bottom:32px}
.eval-header{display:flex;align-items:baseline;gap:12px;margin-bottom:18px;border-bottom:1px solid var(--pale);padding-bottom:12px}
.eval-label{font-family:var(--serif-en);font-style:italic;font-size:10px;letter-spacing:.18em;color:var(--light)}
.eval-title{font-family:var(--serif-jp);font-size:14px;font-weight:600;color:var(--deep)}
.eval-axes{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.eval-row{display:grid;grid-template-columns:130px 1fr 40px;gap:10px;align-items:start}
@media(max-width:540px){.eval-row{grid-template-columns:100px 1fr 36px}}
.eval-name{font-size:12px;font-weight:500;color:var(--ink);letter-spacing:.03em;padding-top:2px}
.eval-bar-wrap{display:flex;flex-direction:column;gap:3px}
.eval-bar{height:8px;border-radius:100px;background:linear-gradient(90deg,var(--c),color-mix(in srgb,var(--c) 70%,white));width:calc(var(--sc)/5*100%);transition:width .8s cubic-bezier(.16,1,.3,1)}
.eval-score{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--navy);line-height:1.2;text-align:right}
.eval-score span{font-size:9px;color:var(--light)}
.eval-comment{grid-column:1/-1;font-size:11px;color:var(--light);line-height:1.65;letter-spacing:.03em;padding-top:0;border-top:none}
@media(min-width:640px){.eval-row{grid-template-columns:130px 1fr 40px 1fr}.eval-comment{grid-column:4;padding-top:2px}}
.eval-total{background:white;border:1.5px solid var(--pale);border-radius:12px;padding:16px 18px;display:flex;flex-wrap:wrap;gap:8px 16px;align-items:center}
.eval-total-label{font-size:10px;letter-spacing:.12em;color:var(--light);width:100%;font-family:var(--serif-en);font-style:italic}
.eval-total-stars{font-size:20px;color:#F59E0B;letter-spacing:2px}
.eval-total-grade{font-family:var(--mono);font-size:18px;font-weight:600;color:var(--navy)}
.eval-total-text{width:100%;font-size:12.5px;color:var(--body);line-height:1.85;letter-spacing:.03em;border-top:1px solid var(--pale);padding-top:10px;margin-top:4px}
/* ─── 移住フッター ─── */
.mv-footer{background:var(--deep);padding:48px 24px;text-align:center}
.mf-logo{font-family:var(--serif-jp);font-size:16px;font-weight:600;color:#C4DFEE;letter-spacing:.06em;margin-bottom:6px}
.mf-sub{font-size:11px;color:rgba(196,223,238,.4);letter-spacing:.06em;margin-bottom:22px}
.mf-links{display:flex;justify-content:center;gap:22px;flex-wrap:wrap;margin-bottom:18px}
.mf-links button{font-size:11.5px;color:rgba(196,223,238,.5);background:none;border:none;cursor:pointer;transition:color .2s;letter-spacing:.04em;font-family:var(--sans)}
.mf-links button:hover{color:rgba(196,223,238,.9)}
.mf-note{font-size:10.5px;color:rgba(196,223,238,.3);letter-spacing:.04em;line-height:1.9;max-width:520px;margin:0 auto}
/* ─── 移住FAQ（拡張） ─── */
.faq-page-head{padding:28px 0 18px;border-bottom:1px solid var(--pale);margin-bottom:26px;text-align:center}
.faq-page-head h2{font-family:var(--serif-jp);font-size:clamp(1.25rem,3vw,1.6rem);font-weight:700;color:var(--deep);margin-bottom:8px;letter-spacing:.04em}
.faq-page-head p{font-size:.87rem;color:var(--body);line-height:1.9;max-width:500px;margin:0 auto}
.faq-search-wrap{max-width:480px;margin:0 auto 20px}
.faq-search{width:100%;padding:13px 18px 13px 44px;border:2px solid var(--pale);border-radius:50px;font-size:.9rem;outline:none;transition:border-color .3s,box-shadow .3s;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17' height='17' fill='%23999' viewBox='0 0 24 24'%3E%3Cpath d='M15.5 14h-.79l-.28-.27A6.47 6.47 0 0 0 16 9.5 6.5 6.5 0 1 0 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z'/%3E%3C/svg%3E") 14px center no-repeat;box-shadow:0 3px 14px rgba(43,108,176,.09);font-family:var(--sans)}
.faq-search:focus{border-color:var(--blue);box-shadow:0 3px 14px rgba(43,108,176,.18)}
.faq-search::placeholder{color:#aaa}
.faq-count{text-align:center;font-size:.82rem;color:var(--light);margin-bottom:20px}
.faq-count span{font-weight:700;color:var(--blue)}
.faq-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px;justify-content:center}
.faq-tab{padding:6px 16px;border-radius:20px;border:1.5px solid var(--pale);background:#fff;font-size:12px;color:var(--body);cursor:pointer;transition:all .15s;font-family:var(--sans);white-space:nowrap}
.faq-tab:hover{border-color:var(--blue);color:var(--navy)}
.faq-tab.active{background:var(--navy);border-color:var(--navy);color:#fff;font-weight:500}
.faq-list{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.faq-item{border:1.5px solid var(--pale);border-radius:12px;overflow:hidden;background:#fff;transition:box-shadow .25s,border-color .25s}
.faq-item:hover{box-shadow:0 2px 10px rgba(43,108,176,.07);border-color:var(--sky)}
.faq-item.open{border-color:var(--blue);box-shadow:0 3px 16px rgba(43,108,176,.11)}
.faq-cat{display:inline-block;font-size:.65rem;font-weight:700;padding:2px 9px;border-radius:4px;margin-right:8px;letter-spacing:.04em;flex-shrink:0}
.faq-item[data-cat="life"] .faq-cat{background:#e8f3f9;color:#1E4470}
.faq-item[data-cat="child"] .faq-cat{background:#fff3e0;color:#c05700}
.faq-item[data-cat="work"] .faq-cat{background:#e3f2fd;color:#1565c0}
.faq-item[data-cat="house"] .faq-cat{background:#fce4ec;color:#b71c4a}
.faq-item[data-cat="medical"] .faq-cat{background:#f3e5f5;color:#6a1b9a}
.faq-item[data-cat="access"] .faq-cat{background:var(--mist);color:#005f87}
.faq-q{width:100%;display:flex;align-items:center;gap:8px;padding:16px 18px;background:#fff;border:none;font-size:.9rem;font-weight:700;color:var(--ink);cursor:pointer;text-align:left;transition:background .15s;font-family:var(--sans);line-height:1.55}
.faq-q-text{flex:1}
.faq-q:hover{background:rgba(43,108,176,.025)}
.faq-icon{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--mist);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--light);transition:transform .32s,background .25s;line-height:1}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--navy);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .38s ease}
.faq-a-inner{padding:0 18px 18px;border-top:1px solid var(--mist)}
.faq-a-inner p{font-size:.87rem;color:var(--body);line-height:2;margin-top:12px}
.faq-a-inner ul{margin:10px 0 0 16px;font-size:.87rem;color:var(--body);line-height:2}
.faq-a-inner li{margin-bottom:3px}
.faq-a-inner strong{color:var(--ink)}
.faq-highlight{background:linear-gradient(135deg,var(--mist),#eaf4fb);border-left:3px solid var(--blue);padding:10px 14px;border-radius:0 8px 8px 0;margin-top:10px;font-size:.83rem;color:var(--navy);line-height:1.8}
@media(max-width:600px){.faq-q{padding:14px 14px;font-size:.85rem}.faq-a-inner{padding:0 14px 16px}.faq-a-inner p,.faq-a-inner ul{font-size:.83rem}.faq-search-wrap{max-width:100%}}

/* ═══════════════════════════════════════════
   住宅・土地 拡張セクション CSS
   ═══════════════════════════════════════════ */

/* --- 土地スコア 総合ヒーロー --- */
.housing-score-hero{text-align:center;padding:36px 0 28px;border-bottom:1px solid var(--pale);margin-bottom:36px}
.housing-score-hero .genki-label{font-family:var(--serif-en);font-style:italic;font-size:11px;letter-spacing:.22em;color:var(--mid);margin-bottom:12px;display:block}
.housing-score-hero .genki-face{font-size:clamp(56px,12vw,88px);line-height:1;margin-bottom:10px;display:block;filter:drop-shadow(0 4px 12px rgba(0,0,0,.08))}
.housing-score-hero .genki-verdict{font-family:var(--serif-jp);font-size:clamp(22px,4vw,32px);font-weight:700;color:var(--deep);letter-spacing:.05em;margin-bottom:6px}
.housing-score-hero .genki-sub{font-size:12.5px;color:var(--light);letter-spacing:.05em}
.housing-score-hero .genki-score-total{display:inline-flex;align-items:baseline;gap:4px;margin:14px 0 0}
.housing-score-hero .genki-score-num{font-family:var(--mono);font-size:clamp(48px,10vw,72px);font-weight:500;color:var(--navy);line-height:1}
.housing-score-hero .genki-score-max{font-family:var(--mono);font-size:16px;color:var(--light);margin-left:2px}
.housing-score-hero .genki-year{font-size:11px;color:var(--light);letter-spacing:.06em;margin-top:4px}

/* 総評コメント */
.housing-verdict-comments{display:flex;flex-direction:column;gap:8px;margin-bottom:28px;max-width:640px;margin-left:auto;margin-right:auto}
.housing-verdict-item{display:flex;align-items:flex-start;gap:8px;padding:10px 16px;background:var(--mist);border-radius:10px;font-size:13px;color:var(--body);line-height:1.7}
.housing-verdict-item .hv-icon{flex-shrink:0;margin-top:2px}

/* --- 比較テーブル --- */
.hs-compare-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:8px}
.hs-compare-tbl{width:100%;border-collapse:collapse;font-size:12px;min-width:640px}
.hs-compare-tbl thead tr{background:var(--navy)}
.hs-compare-tbl th{text-align:center;padding:9px 8px;font-weight:500;color:rgba(240,248,252,.85);border-bottom:2px solid var(--pale);line-height:1.4}
.hs-compare-tbl th.hl-col{background:rgba(255,255,255,.07);color:#A8D8EE;font-weight:600}
.hs-compare-tbl td{padding:8px 8px;text-align:center;border-bottom:1px solid var(--mist);font-size:12px;color:var(--body)}
.hs-compare-tbl tr.is-kahoku{background:rgba(43,108,176,.06)}
.hs-compare-tbl tr.is-kahoku td{color:var(--navy);font-weight:600}
.hs-compare-tbl .rank-badge{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:10px;font-weight:700;color:#fff;margin-right:4px}
.rank-1{background:linear-gradient(135deg,#F59E0B,#D97706)}
.rank-2{background:linear-gradient(135deg,#94A3B8,#64748B)}
.rank-3{background:linear-gradient(135deg,#D4A574,#B8875A)}
.rank-other{background:var(--mid);opacity:.6}

/* --- 横棒グラフ比較 --- */
.hs-bar-section{margin-bottom:28px}
/* 補助金比較 */
.subsidy-city-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.sct-btn{padding:7px 14px;border:1.5px solid var(--pale);border-radius:20px;background:#fff;color:var(--body);font-size:12.5px;cursor:pointer;transition:all .15s;font-family:var(--serif-jp)}
.sct-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.sct-btn:hover:not(.active){background:var(--mist)}
.scc-btn{padding:5px 11px;border:1.5px solid var(--pale);border-radius:16px;background:#fff;color:var(--body);font-size:11.5px;cursor:pointer;transition:all .15s;white-space:nowrap}
.scc-btn.active{background:var(--mid);color:#fff;border-color:var(--mid)}
.scc-btn:hover:not(.active){background:var(--mist)}
.subsidy-city-panel-inner{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:14px 0}
@media(max-width:520px){.subsidy-city-panel-inner{grid-template-columns:1fr}}
.scp-card{padding:14px;background:#fff;border:1.5px solid var(--pale);border-radius:12px;cursor:pointer;transition:box-shadow .2s}
.scp-card:hover{box-shadow:0 2px 12px rgba(0,0,0,.08)}
.scp-card.open .scp-body{display:block}
.scp-head{display:flex;align-items:flex-start;gap:8px}
.scp-cat{font-size:10px;letter-spacing:.06em;color:var(--blue);font-weight:500;margin-bottom:3px}
.scp-name{font-size:13px;font-weight:600;color:var(--deep);line-height:1.4}
.scp-target{font-size:10.5px;color:var(--mid);margin-top:2px}
.scp-body{display:none;margin-top:10px;padding-top:10px;border-top:1px solid var(--mist);font-size:11.5px;color:var(--body);line-height:1.8}
.scp-dept{font-size:10.5px;color:var(--light);margin-top:6px}
.scp-link{display:inline-block;margin-top:6px;font-size:11px;color:var(--blue);text-decoration:none}

.hs-bar-title{font-family:var(--serif-jp);font-size:14px;font-weight:600;color:var(--deep);margin-bottom:12px;letter-spacing:.04em}
.hs-bar-list{display:flex;flex-direction:column;gap:6px}
.hs-bar-row{display:flex;align-items:center;gap:8px}
.hs-bar-name{min-width:70px;font-size:12px;color:var(--body);text-align:right;flex-shrink:0}
.hs-bar-name.hl{color:var(--navy);font-weight:700}
.hs-bar-track{flex:1;height:22px;background:var(--mist);border-radius:6px;overflow:hidden;position:relative}
.hs-bar-fill{height:100%;border-radius:6px;transition:width 1.2s cubic-bezier(.16,1,.3,1);position:relative;display:flex;align-items:center;justify-content:flex-end;padding-right:8px}
.hs-bar-inner-val{font-family:var(--mono);font-size:10px;color:#fff;font-weight:500;white-space:nowrap}
.hs-bar-val{min-width:90px;font-family:var(--mono);font-size:12px;color:var(--body);text-align:left;flex-shrink:0}
.hs-bar-val.hl{color:var(--navy);font-weight:600}

/* --- レーダーチャート --- */
.hs-radar-wrap{display:flex;justify-content:center;margin:24px 0 32px}
.hs-radar-wrap canvas{max-width:360px;width:100%}

/* --- シミュレーション --- */
.sim-container{background:#fff;border:1.5px solid var(--pale);border-radius:18px;padding:24px;margin-bottom:28px}
.sim-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:680px){.sim-grid{grid-template-columns:1fr}}
.sim-input-group{margin-bottom:14px}
.sim-label{font-size:12px;font-weight:500;color:var(--deep);margin-bottom:6px;display:flex;align-items:center;gap:6px;letter-spacing:.03em}
.sim-label .sim-unit{font-size:10px;color:var(--light);font-weight:400}
.sim-input-row{display:flex;align-items:center;gap:8px}
.sim-slider{-webkit-appearance:none;appearance:none;flex:1;height:6px;background:var(--mist);border-radius:3px;outline:none;cursor:pointer}
.sim-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--navy);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.15)}
.sim-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--navy);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.15)}
.sim-number{width:110px;padding:7px 10px;border:1.5px solid var(--pale);border-radius:8px;font-family:var(--mono);font-size:13px;color:var(--navy);text-align:right;outline:none;transition:border-color .2s}
.sim-number:focus{border-color:var(--blue)}
.sim-toggle-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding:8px 12px;background:var(--mist);border-radius:10px}
.sim-toggle-label{font-size:12px;color:var(--body);flex:1}
.sim-toggle{position:relative;width:40px;height:22px;background:var(--pale);border-radius:11px;cursor:pointer;transition:background .2s;flex-shrink:0}
.sim-toggle.active{background:var(--green)}
.sim-toggle::after{content:'';position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:transform .2s}
.sim-toggle.active::after{transform:translateX(18px)}

/* シミュレーション結果 */
.sim-results{background:linear-gradient(135deg,#18344F,#1E4470);border-radius:18px;padding:24px;color:#F0F8FC}
.sim-result-title{font-family:var(--serif-en);font-size:11px;letter-spacing:.2em;color:rgba(168,216,238,.6);margin-bottom:16px}
.hs-sim-result-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;margin-bottom:14px}
@media(max-width:480px){.sim-result-grid{grid-template-columns:1fr}}
.sim-result-item{padding:10px 12px;background:rgba(255,255,255,.06);border-radius:10px;border:1px solid rgba(255,255,255,.08)}
.sim-result-label{font-size:10px;color:rgba(168,216,238,.7);letter-spacing:.04em;margin-bottom:2px}
.sim-result-val{font-family:var(--mono);font-size:16px;font-weight:500;color:#E0F0FA}
.sim-result-highlight{grid-column:1/-1;padding:16px 18px;background:rgba(21,128,61,.15);border:1.5px solid rgba(52,211,153,.3);border-radius:14px;text-align:center}
.sim-result-highlight .sim-result-val{font-size:28px;color:#4ADE80}
.sim-result-compare{grid-column:1/-1;padding:14px;background:rgba(255,255,255,.04);border-radius:12px;text-align:center;border-top:1px solid rgba(255,255,255,.08);margin-top:2px}
.sim-compare-label{font-size:11px;color:rgba(168,216,238,.6);margin-bottom:6px}
.sim-compare-val{font-family:var(--mono);font-size:22px;font-weight:600}
.sim-compare-val.cheaper{color:#4ADE80}
.sim-compare-val.pricier{color:#FCA5A5}
.sim-compare-desc{font-size:11px;color:rgba(168,216,238,.5);margin-top:4px}

/* --- エリアマップ --- */
.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:24px}@media(max-width:560px){.area-grid{grid-template-columns:1fr}}
.area-card{background:#fff;border:1.5px solid var(--pale);border-radius:14px;padding:18px;cursor:pointer;transition:border-color .2s,box-shadow .2s}
.area-card:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(43,108,176,.08)}
.area-card.active{border-color:var(--navy);box-shadow:0 4px 16px rgba(43,108,176,.12)}
.area-card-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.area-card-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}
.area-card-name{font-family:var(--serif-jp);font-size:15px;font-weight:600;color:var(--deep)}
.area-card-price{font-family:var(--mono);font-size:11px;color:var(--navy);background:rgba(43,108,176,.08);padding:2px 8px;border-radius:6px;margin-left:auto}
.area-card-body{font-size:12px;color:var(--body);line-height:1.8;margin-bottom:10px}
.area-card-tags{display:flex;flex-wrap:wrap;gap:4px}
.area-card-tag{font-size:10px;padding:3px 8px;border-radius:6px;background:var(--mist);color:var(--body)}
.area-detail{display:none;padding:14px 0 0;border-top:1px solid var(--mist);margin-top:12px;font-size:12px;color:var(--body);line-height:1.8}
.area-card.active .area-detail{display:block}
.area-detail-row{display:flex;gap:8px;margin-bottom:4px}
.area-detail-label{min-width:90px;color:var(--light);flex-shrink:0;font-size:11px}
.area-detail-val{color:var(--ink)}

/* --- 補助金カード --- */
.subsidy-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.subsidy-filter-btn{padding:6px 14px;border-radius:20px;border:1.5px solid var(--pale);background:#fff;font-size:12px;color:var(--body);cursor:pointer;transition:all .15s;font-family:var(--sans)}
.subsidy-filter-btn:hover{border-color:var(--blue);color:var(--navy)}
.subsidy-filter-btn.active{background:var(--navy);border-color:var(--navy);color:#fff;font-weight:500}
.subsidy-list{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.subsidy-card{background:#fff;border:1.5px solid var(--pale);border-radius:14px;overflow:hidden;transition:border-color .2s}
.subsidy-card:hover{border-color:var(--mid)}
.subsidy-card.featured{border-color:var(--green);border-width:2px}
.subsidy-head{display:flex;align-items:center;gap:12px;padding:14px 18px;cursor:pointer;user-select:none}
.subsidy-icon{font-size:20px;flex-shrink:0}
.subsidy-info{flex:1;min-width:0}
.subsidy-name{font-size:14px;font-weight:600;color:var(--deep);margin-bottom:2px}
.subsidy-brief{font-size:11px;color:var(--light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.subsidy-amount{font-family:var(--mono);font-size:14px;font-weight:600;color:var(--green);white-space:nowrap;margin-left:auto;padding-left:12px}
.subsidy-chevron{font-size:14px;color:var(--light);transition:transform .2s;flex-shrink:0}
.subsidy-card.open .subsidy-chevron{transform:rotate(90deg)}
.subsidy-body{display:none;padding:0 18px 16px;border-top:1px solid var(--mist)}
.subsidy-card.open .subsidy-body{display:block}
.subsidy-detail-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 12px;font-size:12px;margin-top:12px}
.subsidy-detail-label{color:var(--light);font-size:11px}
.subsidy-detail-val{color:var(--ink);line-height:1.7}
.subsidy-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:10px}
.subsidy-tag{font-size:10px;padding:2px 8px;border-radius:6px;background:var(--mist);color:var(--body)}
.subsidy-tag.tag-featured{background:rgba(21,128,61,.1);color:#15803D}

/* --- 太陽光シミュレーション --- */
.solar-results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
@media(max-width:560px){.solar-results-grid{grid-template-columns:1fr 1fr}}
.solar-result-card{background:#fff;border:1.5px solid var(--pale);border-radius:14px;padding:14px;text-align:center}
.solar-result-card.primary{border-color:var(--green);background:#F0FDF4}
.solar-result-label{font-size:10.5px;color:var(--light);margin-bottom:4px;letter-spacing:.04em}
.solar-result-val{font-family:var(--mono);font-size:18px;font-weight:500;color:var(--navy)}
.solar-result-card.primary .solar-result-val{color:var(--green)}
.solar-timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:16px}
@media(max-width:480px){.solar-timeline{grid-template-columns:1fr}}
.solar-tl-card{background:var(--mist);border-radius:12px;padding:14px;text-align:center}
.solar-tl-year{font-size:12px;font-weight:600;color:var(--deep);margin-bottom:4px}
.solar-tl-val{font-family:var(--mono);font-size:16px;font-weight:500;color:var(--navy)}
.solar-tl-note{font-size:10px;color:var(--light);margin-top:3px}

/* --- 共通ユーティリティ --- */
.hs-section-intro{font-size:13px;color:var(--body);line-height:1.9;margin-bottom:20px;letter-spacing:.03em}
.hs-divider{border:none;border-top:1px solid var(--pale);margin:36px 0}
