:root{
  --bg:#f4f6f8; --panel:#ffffff; --ink:#1f2933; --muted:#6b7785;
  --line:#e2e8ef; --accent:#2f7d6e; --accent2:#c8623c; --chip:#eef3f2;
  --shadow:0 1px 3px rgba(0,0,0,.06),0 6px 24px rgba(0,0,0,.05);
}
*{box-sizing:border-box}
body{margin:0;font-family:"Hiragino Kaku Gothic ProN","Yu Gothic","Meiryo",system-ui,sans-serif;
  background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5}
header{padding:18px 22px;background:linear-gradient(120deg,#2f7d6e,#3f9b86);color:#fff}
header h1{margin:0;font-size:19px;font-weight:700}
header p{margin:4px 0 0;font-size:12.5px;opacity:.9}
.wrap{max-width:1180px;margin:0 auto;padding:18px}
.tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.tab{padding:9px 16px;border:1px solid var(--line);background:var(--panel);border-radius:10px;
  cursor:pointer;font-weight:600;color:var(--muted);font-family:inherit;font-size:14px;line-height:1.2}
.tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.tab:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
/* visually hidden (screen readers / SEO 構造) */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;
  box-shadow:var(--shadow);margin-bottom:18px}
.controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;align-items:end}
label{display:block;font-size:11.5px;color:var(--muted);font-weight:600;margin-bottom:4px}
select,input{width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:8px;
  background:#fff;font-size:13px;font-family:inherit;color:var(--ink)}
.seg{display:flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.seg button{flex:1;padding:8px;border:0;background:#fff;cursor:pointer;font-size:12.5px;color:var(--muted)}
.seg button.on{background:var(--accent);color:#fff}
.chartbox{position:relative;width:100%;margin-top:8px}
.meta{font-size:12px;color:var(--muted);margin-top:10px}
.legend-note{font-size:11.5px;color:var(--muted);background:var(--chip);padding:8px 12px;
  border-radius:8px;margin-top:12px}
.foodpick{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.chip{background:var(--chip);border:1px solid var(--line);border-radius:20px;padding:4px 10px;
  font-size:12px;display:flex;align-items:center;gap:6px}
.chip button{border:0;background:none;cursor:pointer;color:var(--accent2);font-weight:700;font-size:13px}
.results{max-height:220px;overflow:auto;border:1px solid var(--line);border-radius:8px;margin-top:6px}
.results div{padding:6px 10px;cursor:pointer;font-size:12.5px;border-bottom:1px solid #f0f3f5}
.results div:hover{background:var(--chip)}
.hint{font-size:12px;color:var(--muted);margin:2px 0 8px}
.cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px;margin-top:14px}
.scrollrow{display:flex;gap:14px;overflow-x:auto;padding:4px 0 14px;margin-top:14px;align-items:flex-start}
.scrollrow .card{flex:0 0 360px}
.scrollhint{font-size:11.5px;color:var(--muted);margin-top:6px}
/* matrix table */
.mxwrap{overflow:auto;max-height:75vh;border:1px solid var(--line);border-radius:10px;margin-top:14px}
table.mx{border-collapse:separate;border-spacing:0;font-size:12px;width:max-content;min-width:100%}
table.mx th,table.mx td{padding:4px 8px;border-bottom:1px solid #eef2f4;white-space:nowrap}
table.mx thead th{position:sticky;top:0;background:#f0f5f4;z-index:3;text-align:center;font-size:11.5px;color:var(--ink);border-bottom:1px solid var(--line)}
table.mx thead th .u{color:#9aa;font-weight:400;font-size:10.5px}
table.mx th.fcol,table.mx td.fcol{position:sticky;left:0;background:#fff;z-index:2;text-align:left;border-right:1px solid var(--line);max-width:230px;overflow:hidden;text-overflow:ellipsis}
table.mx thead th.fcol{z-index:4;background:#f0f5f4}
table.mx tbody tr:hover td{background:#f7faf9}
table.mx tbody tr:hover td.fcol{background:#eef5f3}
/* matrix cell: bar + distribution markers */
.cb{display:flex;align-items:center;gap:6px;min-width:158px}
.cb.empty{min-width:158px;justify-content:flex-end;color:#bbb;padding-right:6px}
.cbsvg{flex:0 0 112px;height:20px;display:block}
.cbval{flex:1;text-align:right;font-size:11px;color:#2b3640;font-variant-numeric:tabular-nums;white-space:nowrap}
.cbval.over{color:#d64541;font-weight:700}
.tierkey{display:inline-flex;align-items:center;gap:3px;margin:0 4px;white-space:nowrap}
.tierkey i{display:inline-block;width:11px;height:11px;border-radius:2px}
/* cards */
.card{border:1px solid var(--line);border-radius:12px;padding:12px}
.card h3{margin:0 0 6px;font-size:13.5px;color:var(--accent)}
.card .cc{position:relative;height:360px}
/* nutrient picker */
.nutpicker{border:1px solid var(--line);border-radius:10px;padding:10px;max-height:340px;overflow:auto;margin-top:6px}
.nutpicker .toolbar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;position:sticky;top:0;background:#fff;padding-bottom:6px;z-index:2}
.pbtn{font-size:11.5px;padding:4px 11px;border:1px solid var(--line);background:#fff;border-radius:16px;cursor:pointer;color:var(--muted);font-family:inherit}
.pbtn:hover{background:var(--chip);color:var(--ink)}
.pbtn.solid{background:var(--accent);color:#fff;border-color:var(--accent)}
.catsec{margin-bottom:10px}
.cathead{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;color:var(--ink);padding:5px 0;border-bottom:1px solid #eef2f4;margin-bottom:5px;cursor:pointer}
.cathead input{width:auto;cursor:pointer}
.catcolor{display:inline-block;width:10px;height:10px;border-radius:2px}
.selcount{font-size:11px;color:var(--muted);margin-left:auto;font-weight:500}
.catitems{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:1px 10px}
.catitems label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink);margin:0;font-weight:400;cursor:pointer;padding:3px 2px;border-radius:5px}
.catitems label:hover{background:var(--chip)}
.catitems input{width:auto;cursor:pointer}
.catitems label span{color:#9aa;font-size:11px}
/* loading / error */
#status{padding:40px;text-align:center;color:var(--muted)}
/* about / footer (SEO crawlable content) */
.site-about{max-width:1180px;margin:8px auto 40px;padding:18px;border-top:1px solid var(--line);color:var(--muted);font-size:13px;line-height:1.8}
.site-about h2{font-size:15px;color:var(--ink);margin:18px 0 6px}
.site-about ul{margin:6px 0;padding-left:1.2em}
.site-about a{color:var(--accent)}
.site-about .src{font-size:12px;margin-top:16px}
.faq dt{font-weight:600;color:var(--ink);margin-top:12px}
.faq dd{margin:4px 0 0;padding-left:0}
/* 生成された解説ページ（食品・栄養素・食品群） */
.article{max-width:920px;margin:0 auto;padding:22px 18px 60px}
.crumbs{font-size:12px;color:var(--muted);margin-bottom:14px}
.crumbs a{color:var(--accent);text-decoration:none}
.article h1{font-size:22px;line-height:1.4;margin:6px 0 10px}
.article h2{font-size:16px;margin:26px 0 8px;border-left:4px solid var(--accent);padding-left:8px}
.article p{margin:8px 0}
.lead{color:var(--ink)}
.pill{display:inline-block;background:var(--chip);border:1px solid var(--line);border-radius:16px;padding:3px 11px;margin:3px 4px 3px 0;font-size:13px;color:var(--accent);text-decoration:none}
.pill:hover{background:var(--accent);color:#fff}
table.data,table.rank{border-collapse:collapse;width:100%;font-size:13px;margin:10px 0}
table.data th,table.data td,table.rank th,table.rank td{border-bottom:1px solid var(--line);padding:6px 8px;text-align:left}
table.data td.num,table.rank td.num,table.rank th.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
table.data thead th,table.rank thead th{background:#f0f5f4;font-size:12px}
table.rank td a{color:var(--accent);text-decoration:none}
table.rank td a:hover{text-decoration:underline}
.catrow th{background:#eef3f2;color:var(--accent);font-weight:700}
.linklist{columns:2;font-size:13px;margin:8px 0}
.linklist a{color:var(--accent);text-decoration:none;display:block;padding:2px 0}
@media(max-width:640px){.linklist{columns:1}}
.toapp{display:inline-block;margin:14px 0;background:var(--accent);color:#fff;padding:9px 16px;border-radius:8px;text-decoration:none;font-weight:600}
.pagefoot{margin-top:30px;border-top:1px solid var(--line);padding-top:14px;font-size:12px;color:var(--muted)}
.pagefoot a{color:var(--accent)}
/* インラインのミニグラフ（ブラウザ側で /enhance.js が描画） */
.gcell{width:130px}
.boxg{display:inline-block;width:124px;height:18px;vertical-align:middle}
.boxg-na{color:#c4ccd2}
.gbar{display:inline-block;width:88px;height:9px;background:#eef2f4;border-radius:3px;vertical-align:middle;overflow:hidden;margin-left:6px}
.gbar i{display:block;height:100%;border-radius:3px}
.boxlegend{font-size:11.5px;color:var(--muted);background:var(--chip);padding:8px 12px;border-radius:8px;margin:8px 0}
.boxlegend span{font-weight:700}
