@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&family=Plus+Jakarta+Sans:wght@200;300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  /* Palette: deep midnight with warm accents */
  --bg:#07080c; --bg2:#0d0f14; --bg3:#13151c; --bg4:#1a1d26;
  --surface:#181b24; --surface2:#1f222d; --surface3:#262a36;
  --fg:#f0ede8; --fg2:#b5b0a8; --fg3:#7a756e; --fg4:#4a4640;
  /* Accent system */
  --coral:#e86b47; --blue:#4a9eff; --green:#3dd68c; --purple:#a78bfa;
  --red:#f0544f; --amber:#f4b942; --pink:#f472b6;
  --border:rgba(255,255,255,.05); --border2:rgba(255,255,255,.08);
  /* Typography */
  --sans:'Plus Jakarta Sans','Noto Sans JP',sans-serif;
  --jp:'Noto Sans JP',sans-serif;
  --mono:'JetBrains Mono',monospace;
  /* Motion */
  --ease:cubic-bezier(.4,0,.2,1); --ease-out:cubic-bezier(0,0,.2,1);
  /* Radius */
  --r-sm:6px; --r-md:10px; --r-lg:16px; --r-xl:24px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth}
body{background:var(--bg);color:var(--fg);font-family:var(--sans);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}

a{color:inherit;text-decoration:none}
button{font-family:inherit}

/* ===== LAYOUT ===== */
.page{max-width:1080px;margin:0 auto;padding:0 32px;min-height:100vh}

/* ===== HEADER ===== */
.header{display:flex;justify-content:space-between;align-items:center;padding:20px 0;position:sticky;top:0;z-index:100;background:rgba(7,8,12,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.header::after{content:'';position:absolute;bottom:0;left:-32px;right:-32px;height:1px;background:var(--border)}
.header-brand{display:flex;align-items:center;gap:10px;cursor:pointer;transition:opacity .3s}
.header-brand:hover{opacity:.8}
.header-logo{font-family:var(--jp);font-weight:900;font-size:1rem;letter-spacing:.03em}
.header-sub{font-family:var(--sans);font-weight:300;font-size:.6rem;color:var(--fg3);letter-spacing:.2em;text-transform:uppercase}
.header-right{display:flex;align-items:center;gap:8px}

/* API Badge */
.api-badge{font-family:var(--mono);font-size:.58rem;letter-spacing:.04em;padding:4px 10px;border-radius:100px;border:1px solid var(--border2);color:var(--fg4);transition:all .3s}
.api-badge.live{color:var(--green);border-color:rgba(61,214,140,.2);background:rgba(61,214,140,.05)}

/* Refresh */
.refresh-btn{display:inline-flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--border2);color:var(--fg3);font-size:.6rem;font-weight:500;padding:5px 10px;border-radius:100px;cursor:pointer;transition:all .25s var(--ease)}
.refresh-btn:hover{color:var(--fg);border-color:var(--fg4);background:var(--surface2)}
.refresh-btn.loading .icon{animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== HERO ===== */
.hero-wrap{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-canvas{position:absolute;inset:0;width:100%;height:100%}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 45%,transparent,rgba(7,8,12,.6) 55%,rgba(7,8,12,.98) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;padding:40px 24px}
.hero-scroll{position:absolute;bottom:28px;z-index:2;text-align:center}
.hero-scroll span{font-family:var(--sans);font-size:.5rem;letter-spacing:.35em;color:var(--fg4);text-transform:uppercase}
.hero-scroll::after{content:'';display:block;width:1px;height:36px;background:linear-gradient(var(--fg4),transparent);margin:8px auto 0;animation:scrollP 2.5s ease infinite}
@keyframes scrollP{0%{opacity:0;transform:scaleY(0);transform-origin:top}30%{opacity:1;transform:scaleY(1)}60%{transform-origin:bottom}100%{opacity:0;transform:scaleY(0);transform-origin:bottom}}

.hero-eyebrow{font-weight:300;font-size:.65rem;letter-spacing:.4em;color:var(--fg4);text-transform:uppercase;margin-bottom:20px}
.hero-number{font-weight:800;font-size:clamp(3rem,10vw,7rem);line-height:1;letter-spacing:-.04em;background:linear-gradient(135deg,var(--fg) 20%,var(--coral) 60%,var(--amber) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-unit{display:block;font-family:var(--jp);font-weight:300;font-size:.8rem;color:var(--fg3);letter-spacing:.15em;margin-top:6px;-webkit-text-fill-color:var(--fg3)}
.hero-delta{font-family:var(--mono);font-size:.72rem;color:var(--coral);margin-top:14px}
.hero-chips{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-top:24px}
.chip{font-size:.6rem;font-weight:500;padding:4px 12px;border:1px solid var(--border2);border-radius:100px;color:var(--fg3);backdrop-filter:blur(4px)}

/* ===== PAGE HERO ===== */
.page-hero{padding:64px 0 36px}
.page-title{font-weight:800;font-size:clamp(2rem,6vw,3.5rem);letter-spacing:-.02em;line-height:1.1}
.page-desc{font-size:.82rem;color:var(--fg3);margin-top:12px;max-width:480px}
.back-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--fg4);font-size:.72rem;font-weight:500;cursor:pointer;padding:8px 0;transition:color .25s}
.back-btn:hover{color:var(--fg)}

/* ===== SECTION ===== */
.section-eyebrow{font-weight:300;font-size:.58rem;letter-spacing:.35em;color:var(--coral);text-transform:uppercase;margin-bottom:6px}
.section-title{font-family:var(--jp);font-weight:700;font-size:1.4rem;letter-spacing:.03em;margin-bottom:28px}
.sub-title{font-size:.88rem;font-weight:600;margin-bottom:16px;color:var(--fg)}

/* ===== NAV ITEMS ===== */
.nav-section{padding:64px 0;border-top:1px solid var(--border)}
.nav-list{display:flex;flex-direction:column}
.nav-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:20px 0;border-bottom:1px solid var(--border);background:none;color:var(--fg);cursor:pointer;text-align:left;transition:all .35s var(--ease);text-decoration:none}
.nav-item:first-child{border-top:1px solid var(--border)}
.nav-item:hover{padding-left:16px}
.nav-item:hover .nav-label{color:var(--accent,var(--coral))}
.nav-item:hover .nav-arrow{transform:translateX(6px);opacity:1}
.nav-sublabel{font-weight:300;font-size:.55rem;letter-spacing:.2em;color:var(--fg4);text-transform:uppercase;display:block;margin-bottom:1px}
.nav-label{font-family:var(--jp);font-weight:700;font-size:1.35rem;letter-spacing:.05em;transition:color .35s var(--ease)}
.nav-arrow{transition:all .35s var(--ease);color:var(--fg4);opacity:.5}

/* ===== STAT GRID (Figma card style) ===== */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;margin-bottom:32px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;display:flex;flex-direction:column;gap:4px;transition:border-color .25s,transform .25s}
.stat-card:hover{border-color:var(--border2);transform:translateY(-1px)}
.stat-card-label{font-size:.58rem;font-weight:500;color:var(--fg4);letter-spacing:.05em;text-transform:uppercase}
.stat-card-value{font-weight:700;font-size:1.25rem;line-height:1.2}
.stat-card-value small{font-size:.55rem;font-weight:400;color:var(--fg3);margin-left:2px}

/* ===== MINI CHART (画面内に収まるコンパクト版) ===== */
.chart-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
@media(max-width:640px){.chart-row{grid-template-columns:1fr}}
.chart-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;overflow:hidden}
.chart-box h4{font-size:.72rem;font-weight:600;color:var(--fg2);margin-bottom:12px;letter-spacing:.02em}

/* Bar chart (compact, fits viewport) */
.bar-chart{display:flex;align-items:flex-end;gap:4px;height:155px}
.bar-item{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}
.bar-track{flex:1;width:100%;display:flex;align-items:flex-end}
.bar-fill{width:100%;border-radius:3px 3px 0 0;transition:height 1s var(--ease-out);min-height:2px;opacity:.85}
.bar-fill:hover{opacity:1}
.bar-label{font-family:var(--mono);font-size:.48rem;color:var(--fg4);margin-top:6px}

/* Horizontal bar (compact) */
.hbar-list{display:flex;flex-direction:column;gap:5px}
.hbar-row{display:flex;align-items:center;gap:8px}
.hbar-name{font-size:.68rem;min-width:100px;color:var(--fg3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hbar-track{flex:1;height:8px;background:var(--bg3);border-radius:4px;overflow:hidden}
.hbar-fill{height:100%;border-radius:4px;transition:width 1s var(--ease-out);opacity:.85}
.hbar-val{font-family:var(--mono);font-size:.62rem;min-width:42px;text-align:right;color:var(--fg3)}

/* ===== METRIC SWITCH ===== */
.metric-switch{display:flex;gap:2px;margin-bottom:24px;background:var(--surface);border-radius:var(--r-sm);padding:3px;border:1px solid var(--border)}
.metric-switch button{flex:1;padding:7px 12px;border:none;background:none;color:var(--fg4);font-size:.7rem;font-weight:500;border-radius:4px;cursor:pointer;transition:all .25s}
.metric-switch button.active{background:var(--surface3);color:var(--fg)}

/* ===== PREF GRID ===== */
.pref-grid{display:grid;grid-template-columns:repeat(14,1fr);grid-template-rows:repeat(15,1fr);gap:2px;aspect-ratio:14/15;max-width:480px;margin:0 auto 32px}
.pref-cell{border:none;border-radius:2px;cursor:pointer;font-size:.45rem;color:#fff;display:grid;place-items:center;transition:all .2s;font-family:var(--jp);font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.5);aspect-ratio:1}
.pref-cell:hover{transform:scale(1.3);z-index:10;box-shadow:0 4px 16px rgba(0,0,0,.5);border-radius:3px}

/* ===== RANKING ===== */
.ranking-list{display:flex;flex-direction:column}
.ranking-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 0;border-bottom:1px solid var(--border);background:none;color:var(--fg);cursor:pointer;text-align:left;font-family:var(--sans);transition:padding-left .25s}
.ranking-item:hover{padding-left:10px}
.ranking-num{font-family:var(--mono);font-weight:700;font-size:.72rem;color:var(--fg4);min-width:22px}
.ranking-name{font-size:.8rem;flex:1}
.ranking-value{font-family:var(--mono);font-size:.72rem;color:var(--fg3)}

/* ===== MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:1000;display:grid;place-items:center;padding:24px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.modal-content{background:var(--surface);border-radius:var(--r-xl);padding:32px;max-width:400px;width:100%;border:1px solid var(--border2);animation:modalIn .3s var(--ease-out)}
@keyframes modalIn{from{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:none}}
.modal-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--fg4);font-size:1.3rem;cursor:pointer}
.modal-close:hover{color:var(--fg)}
.modal-title{font-weight:700;font-size:1.3rem;margin-bottom:20px}
.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.modal-stat{display:flex;flex-direction:column;gap:2px}
.modal-stat-label{font-size:.58rem;color:var(--fg4);letter-spacing:.06em;text-transform:uppercase}
.modal-stat-value{font-weight:700;font-size:1.3rem}
.modal-stat-value small{font-size:.6rem;font-weight:400;color:var(--fg3);margin-left:2px}
.modal-source{font-size:.55rem;color:var(--fg4);margin-top:16px}

/* ===== INCOME BAR ===== */
.income-bar-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border)}
.income-rank{font-family:var(--mono);font-weight:700;font-size:.7rem;color:var(--fg4);min-width:22px}
.income-pref{font-size:.78rem;min-width:70px}
.income-bar-track{flex:1;height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}
.income-bar-fill{height:100%;background:var(--blue);border-radius:3px;transition:width 1s var(--ease-out)}
.income-value{font-family:var(--mono);font-size:.75rem;min-width:60px;text-align:right}
.income-value small{font-size:.55rem;color:var(--fg3);margin-left:1px}

/* ===== LIFE CARDS ===== */
.life-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media(max-width:640px){.life-grid{grid-template-columns:repeat(2,1fr)}}
.life-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;display:flex;flex-direction:column;gap:4px;transition:border-color .25s}
.life-card:hover{border-color:var(--green)}
.life-item{font-weight:700;font-size:.95rem}
.life-city{font-size:.62rem;color:var(--green);letter-spacing:.03em;font-weight:500}
.life-amount{font-weight:600;font-size:1.1rem;margin-top:2px}
.life-amount small{font-size:.55rem;color:var(--fg4);margin-left:2px}

/* ===== EXPLORER ===== */
.explorer-info{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;margin-bottom:16px}
.explorer-info h3{font-size:.88rem;font-weight:600;margin-bottom:10px}
.explorer-info p{font-size:.78rem;color:var(--fg3)}
.explorer-links{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.explorer-link{font-size:.7rem;font-weight:500;color:var(--amber);padding:6px 12px;border:1px solid rgba(244,185,66,.2);border-radius:var(--r-sm);transition:all .25s}
.explorer-link:hover{background:rgba(244,185,66,.1);border-color:var(--amber)}
.code-list{display:flex;flex-direction:column;gap:4px}
.code-item{display:flex;align-items:center;gap:12px;padding:7px 0;border-bottom:1px solid var(--border)}
.code-item code{font-family:var(--mono);font-size:.65rem;color:var(--coral);background:var(--bg3);padding:2px 7px;border-radius:3px}
.code-item span{font-size:.78rem;flex:1}

/* ===== INFO CARD ===== */
.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;margin:16px 0}
.info-card h3{font-size:.85rem;font-weight:600;margin-bottom:8px}
.info-card p{font-size:.75rem;color:var(--fg3);line-height:1.8;margin-bottom:5px}
.info-source{font-size:.58rem!important;color:var(--fg4)!important}

/* ===== SECTION SPACER ===== */
.section-spacer{padding:28px 0;border-top:1px solid var(--border)}
.trend-note{font-size:.72rem;color:var(--fg4);margin-top:14px}

/* ===== FOOTER ===== */
footer{text-align:center;padding:40px 24px;border-top:1px solid var(--border);margin-top:32px}
footer p{font-size:.58rem;color:var(--fg4);line-height:2}
.footer-brand{font-family:var(--sans);font-size:.78rem;font-weight:500;letter-spacing:.1em;margin-bottom:4px}
.footer-brand a{color:var(--coral);transition:opacity .25s}
.footer-brand a:hover{opacity:.7}

/* ===== FADE ===== */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.fade-in.visible{opacity:1;transform:none}
.anim-fade{opacity:0;animation:fadeUp .8s var(--ease-out) forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* ===== RESPONSIVE ===== */
@media(max-width:640px){
  .page{padding:0 16px}
  .header{padding:16px 0}
  .nav-label{font-size:1.15rem}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .pref-grid{max-width:100%}
  .pref-cell{font-size:.38rem}
  .bar-chart{height:110px}
  .hbar-name{min-width:72px;font-size:.6rem}
  .chart-row{grid-template-columns:1fr}
}

/* ===== WIDE MODAL ===== */
.modal-wide{max-width:560px}
.modal-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px}
.modal-sub{font-size:.7rem;color:var(--fg3);margin-top:2px}
.modal-governor{display:flex;align-items:center;gap:10px;text-align:right}
.governor-photo{width:48px;height:48px;border-radius:50%;background:var(--bg3);background-size:cover;background-position:center;flex-shrink:0;border:2px solid var(--border2)}
.governor-photo.has-photo{border-color:var(--coral)}
.modal-gov-label{font-size:.55rem;color:var(--fg4);display:block;letter-spacing:.06em}
.modal-gov-name{font-size:.82rem;font-weight:600}
.modal-grid-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:480px){.modal-grid-3{grid-template-columns:repeat(2,1fr)}}
.modal-wiki{margin:14px 0 10px}
.wiki-extract{font-size:.72rem;color:var(--fg3);line-height:1.8;max-height:120px;overflow-y:auto}
.modal-loading{font-size:.68rem;color:var(--fg4);animation:pulse 1.5s ease infinite}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}
.modal-links{display:flex;gap:8px;margin:12px 0 8px}
.modal-link{font-size:.65rem;font-weight:500;color:var(--coral);padding:5px 10px;border:1px solid rgba(232,107,71,.2);border-radius:var(--r-sm);transition:all .25s}
.modal-link:hover{background:rgba(232,107,71,.1)}

/* Person modal */
.person-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.person-photo{width:72px;height:72px;border-radius:50%;background:var(--bg3);background-size:cover;background-position:center top;flex-shrink:0;border:2px solid var(--border2)}
.person-no-photo{display:grid;place-items:center}
.person-loading{text-align:center;padding:32px}

/* Pref hyperlink */
.pref-link{color:var(--coral);text-decoration:none;border-bottom:1px dotted rgba(232,107,71,.3);transition:all .2s;cursor:pointer}
.pref-link:hover{color:var(--fg);border-bottom-color:var(--fg)}

/* ===== HERO COMPACT (fits viewport) ===== */
.hero-compact{min-height:auto;height:100vh;max-height:100vh}
.hero-compact .hero-content{padding:20px 24px}
.hero-bottom{margin-top:auto;padding:0 32px 20px;position:relative;z-index:2}
.hero-chart-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:640px){.hero-chart-row{grid-template-columns:1fr}}
.hero-chart-box{background:rgba(13,15,20,.7);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;backdrop-filter:blur(8px)}
.hero-chart-box h4{font-size:.6rem;font-weight:500;color:var(--fg3);margin-bottom:8px;letter-spacing:.03em}
.hero-stat-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px;justify-content:center}
.hero-stat{background:rgba(13,15,20,.6);border:1px solid var(--border);border-radius:var(--r-sm);padding:6px 12px;text-align:center;backdrop-filter:blur(4px)}
.hero-stat-label{font-size:.48rem;color:var(--fg4);display:block;letter-spacing:.04em;text-transform:uppercase}
.hero-stat-val{font-weight:700;font-size:.88rem;line-height:1.2}
.hero-stat-val small{font-size:.5rem;font-weight:400;color:var(--fg3);margin-left:1px}

/* Clickable governor list */
.gov-list{display:flex;flex-direction:column;gap:3px}
.gov-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-sm);cursor:pointer;transition:background .2s;border:1px solid transparent}
.gov-item:hover{background:var(--surface2);border-color:var(--border2)}
.gov-item .gov-thumb{width:32px;height:32px;border-radius:50%;background:var(--bg3);background-size:cover;background-position:center;flex-shrink:0}
.gov-item .gov-info{flex:1}
.gov-item .gov-pref{font-size:.68rem;color:var(--fg3)}
.gov-item .gov-name{font-size:.78rem;font-weight:600}

/* ===== CHART WITH Y-AXIS ===== */
.chart-with-axis{display:flex;gap:4px;align-items:stretch}
.bar-yaxis{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;padding:0 4px 22px 0;min-width:36px}
.bar-yaxis span{font-family:var(--mono);font-size:.48rem;color:var(--fg4);line-height:1}
.chart-with-axis .bar-chart{flex:1}

/* ===== TOOLTIP (positioned to the side, not overlapping) ===== */
.chart-tooltip{position:fixed;z-index:2000;background:var(--surface3);color:var(--fg);font-size:.68rem;font-weight:500;padding:6px 12px;border-radius:var(--r-sm);border:1px solid var(--border2);pointer-events:none;white-space:nowrap;display:none;box-shadow:0 4px 16px rgba(0,0,0,.5);font-family:var(--mono);transition:left .1s ease,top .1s ease}

/* ===== CHART ZOOM MODAL ===== */
.chart-zoom-modal{background:var(--bg2);border-radius:var(--r-xl);padding:8px;max-width:720px;width:95vw;position:relative;border:1px solid var(--border2);animation:modalIn .3s var(--ease-out)}
.chart-zoom-modal .chart-box{border:none;margin:0}
.chart-zoom-modal .bar-chart{height:320px!important}
.chart-zoom-modal .hbar-track{height:14px!important}
.chart-zoom-modal .bar-label{font-size:.6rem!important}
.chart-zoom-modal .hbar-name{font-size:.78rem!important;min-width:120px!important}
.chart-zoom-modal .hbar-val{font-size:.75rem!important}
.chart-zoom-modal .bar-yaxis span{font-size:.58rem!important}
.chart-zoom-modal .donut-ring{width:200px!important;height:200px!important}

/* Bar hover */
.bar-item{cursor:pointer;transition:opacity .2s}
.bar-item:hover .bar-fill{opacity:1!important;filter:brightness(1.2)}
.hbar-row{cursor:pointer;transition:background .15s;border-radius:4px;padding:3px 4px;margin:-3px -4px}
.hbar-row:hover{background:var(--surface)}

/* ===== DONUT CHART ===== */
.donut-wrap{display:flex;align-items:center;gap:16px;cursor:pointer}
.donut-ring{width:120px;height:120px;border-radius:50%;position:relative;flex-shrink:0}
.donut-hole{position:absolute;inset:25%;background:var(--surface);border-radius:50%;display:grid;place-items:center}
.donut-total{font-weight:700;font-size:.72rem;color:var(--fg2);text-align:center;line-height:1.2}
.donut-legend{display:flex;flex-direction:column;gap:4px;flex:1}
.donut-legend-item{display:flex;align-items:center;gap:6px;font-size:.65rem;cursor:pointer;padding:2px 0;transition:opacity .2s}
.donut-legend-item:hover{opacity:.7}
.donut-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.donut-label{flex:1;color:var(--fg2)}
.donut-val{font-family:var(--mono);font-weight:500;color:var(--fg)}

/* ===== SVG LINE CHART ===== */
.chart-box svg{display:block}
.chart-box svg circle{transition:r .15s,fill-opacity .15s;cursor:pointer}
.chart-box svg circle:hover{r:2;fill-opacity:1}
.chart-box svg rect{transition:fill-opacity .15s;cursor:pointer}
.chart-box svg rect:hover{fill-opacity:1!important}

/* Zoom modal SVG scaling */
.chart-zoom-modal svg{max-height:400px}
.chart-zoom-modal .hero-chart-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:20px}

/* ===== Hero with tall pyramid ===== */
.hero-compact{min-height:100vh;max-height:none;height:auto}
.hero-compact .hero-content{padding-top:80px;padding-bottom:8px}
.hero-bottom{padding-bottom:24px}

/* Pyramid zoom */
.chart-zoom-modal .donut-ring{width:180px!important;height:180px!important}

/* ===== BRIGHT & LARGE chart text ===== */
.bar-yaxis span{font-size:.55rem!important;color:#d0c8b8!important;font-weight:500!important}
.axis-unit{font-size:.46rem!important;color:#f4b942!important;font-weight:600!important;letter-spacing:.02em;margin-bottom:6px!important;display:block!important;line-height:1!important;padding-bottom:2px!important;border-bottom:1px solid rgba(244,185,66,.15)!important}
.bar-label{font-size:.58rem!important;color:#d0c8b8!important;font-weight:500!important}
.bar-val-top{font-family:var(--mono);font-size:.46rem;font-weight:700;color:#fff;text-align:center;display:block;margin-bottom:4px;min-height:13px;line-height:13px;white-space:nowrap;overflow:visible}
.hbar-name{font-size:.72rem!important;color:#d0c8b8!important;font-weight:500!important}
.hbar-val{font-size:.68rem!important;color:#fff!important;font-weight:600!important}
.donut-label{color:#d0c8b8!important;font-size:.68rem!important}
.donut-val{color:#fff!important;font-size:.7rem!important;font-weight:600!important}
.donut-total{color:#fff!important;font-size:.78rem!important}
