/* ===== page: heatmap ===== */
.selpanel { display: flex; flex-direction: column; gap: 18px; background: var(--surface); border: 1px solid var(--line); border-radius: 18px; padding: 22px; }
.sel-block { display: flex; flex-direction: column; gap: 12px; }
.sel-lab { display: flex; align-items: center; gap: 8px; font-family: "IBM Plex Mono", monospace; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.sel-lab .micon { font-size: 16px; color: var(--accent); }
.catrow { display: flex; gap: 11px; flex-wrap: wrap; }
.catcard { display: flex; align-items: center; gap: 11px; background: var(--surface); border: 1.5px solid var(--line); border-radius: 14px; padding: 11px 15px 11px 11px; cursor: pointer; transition: .15s; }
.catcard:hover { border-color: var(--line-strong); transform: translateY(-1px); }
.catcard.active { border-color: var(--accent); background: var(--accent-soft); box-shadow: 0 12px 26px -18px var(--accent); }
.catcard .tile { display: grid; place-items: center; width: 38px; height: 38px; border-radius: 10px; background: var(--surface-2); color: var(--accent-ink); border: 1px solid var(--line-strong); flex: none; transition: .15s; }
.catcard .tile .micon { font-size: 20px; }
.catcard.active .tile { background: var(--accent); color: #fff; border-color: var(--accent); }
.catcard .cc { display: flex; flex-direction: column; gap: 2px; line-height: 1.15; }
.catcard .cn { font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 14.5px; letter-spacing: -.01em; }
.catcard .ci { font-family: "IBM Plex Mono", monospace; font-size: 10.5px; color: var(--muted); }
.catcard.active .ci { color: var(--accent-ink); }

.map-section { display: flex; flex-direction: column; gap: 16px; padding-top: 0; }
.mapwrap { display: grid; grid-template-columns: 1fr 330px; gap: 22px; align-items: start; }
@media (max-width: 940px) { .mapwrap { grid-template-columns: 1fr; } }
.mapcard { background: var(--surface); border: 1px solid var(--line); border-radius: 18px; padding: 12px; position: relative; overflow: hidden; }
.mapcard svg { width: 100%; height: auto; display: block; }
.map-geo path { cursor: pointer; }
.mc-title { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 6px 8px 12px; }
.mc-title .t { font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 18px; letter-spacing: -.01em; }
.mc-title .t small { font-family: "IBM Plex Mono", monospace; font-weight: 500; font-size: 12px; color: var(--muted); }
.mc-readout { font-family: "IBM Plex Mono", monospace; font-size: 12.5px; color: var(--ink-soft); display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.mc-readout .rv { color: var(--accent-ink); font-weight: 600; }
.mc-readout .rst { color: var(--muted); }
.reset-sel { display: inline-flex; align-items: center; gap: 5px; border: 1px solid var(--line-strong); border-radius: 99px; padding: 3px 10px; font-size: 12px; font-weight: 600; color: var(--ink-soft); background: none; cursor: pointer; }
.reset-sel:hover { border-color: var(--ink); color: var(--ink); }
.reset-sel .micon { font-size: 15px; }

.side { display: flex; flex-direction: column; gap: 22px; }
.legend { display: flex; flex-direction: column; gap: 9px; background: var(--surface); border: 1px solid var(--line); border-radius: 14px; padding: 16px; }
.legend .lg-title { font-family: "IBM Plex Mono", monospace; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.legend .lg-bar { display: flex; height: 15px; border-radius: 6px; overflow: hidden; border: 1px solid var(--line); }
.legend .lg-bar span { flex: 1; }
.legend .lg-scale { display: flex; justify-content: space-between; font-family: "IBM Plex Mono", monospace; font-size: 11px; color: var(--muted); }
.legend .lg-nd { display: flex; align-items: center; gap: 8px; font-family: "IBM Plex Mono", monospace; font-size: 11px; color: var(--muted); padding-top: 4px; border-top: 1px dashed var(--line-strong); }
.swatch { width: 14px; height: 14px; border-radius: 4px; border: 1px solid var(--line); flex: none; }
.toppanel { display: flex; flex-direction: column; gap: 10px; background: var(--surface); border: 1px solid var(--line); border-radius: 14px; padding: 16px; }
.toppanel .tp-h { display: flex; align-items: center; gap: 8px; font-family: "IBM Plex Mono", monospace; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.toppanel .tp-h .micon { font-size: 16px; color: var(--spark-ink); }

.tip { position: fixed; pointer-events: none; background: var(--ink); color: #fff; border-radius: 10px; padding: 9px 12px; font-size: 13px; z-index: 80; opacity: 0; transition: opacity .12s; box-shadow: 0 14px 34px -14px rgba(0, 0, 0, .55); max-width: 220px; }
.tip .th { display: flex; align-items: center; gap: 8px; font-weight: 700; }
.tip .tv { font-family: "IBM Plex Mono", monospace; color: var(--spark); margin-top: 3px; font-size: 13.5px; }
.tip .tnd { color: #A7C2BD; font-size: 12px; margin-top: 3px; }

.map-note { color: var(--muted); font-size: 13px; max-width: 90ch; }

/* producers ruler-bar list (top-10) */
.prod { display: flex; flex-direction: column; }
.prow { display: grid; grid-template-columns: 20px minmax(0, 1fr) 52px auto; align-items: center; gap: 10px; padding: 12px 6px; border-bottom: 1px solid var(--line); }
.prow:last-child { border-bottom: none; }
.prow.me { background: var(--accent-soft); border-radius: 10px; border-bottom-color: transparent; }
.prow .rk { font-family: "IBM Plex Mono", monospace; font-size: 13px; color: var(--muted); text-align: right; }
.prow.me .rk { color: var(--accent-ink); font-weight: 600; }
.prow .who { display: flex; align-items: center; gap: 10px; font-weight: 600; font-size: 14.5px; min-width: 0; }
.prow .who .cn { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.prow .track { height: 9px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 5px; position: relative; overflow: hidden; }
.prow .fill { height: 100%; border-radius: 5px; background: var(--line-strong); opacity: 1; position: relative; z-index: 1; }
.prow.me .fill { background: var(--accent); }
.prow .amt { font-family: "IBM Plex Mono", monospace; font-size: 13.5px; font-weight: 600; text-align: right; white-space: nowrap; }
@media (max-width: 620px) { .prow { grid-template-columns: 22px 1fr 78px; gap: 10px; } .prow .track { display: none; } }

/* indicator combobox selector */
.ind-count { font-family: "IBM Plex Mono", monospace; font-size: 11px; color: var(--muted); text-transform: none; letter-spacing: 0; margin-left: 6px; }
.combo { position: relative; max-width: 560px; }
.combo-trigger { display: flex; align-items: center; justify-content: space-between; gap: 12px; width: 100%; background: var(--surface); border: 1.5px solid var(--line-strong); border-radius: 12px; padding: 13px 15px; font: inherit; text-align: left; cursor: pointer; transition: .15s; }
.combo-trigger:hover { border-color: var(--accent); }
.combo.open .combo-trigger { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.ct-main { display: flex; align-items: center; gap: 10px; min-width: 0; }
.ct-dir { font-size: 18px; color: var(--muted); flex: none; }
.ct-name { font-weight: 700; font-size: 15.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ct-unit { font-family: "IBM Plex Mono", monospace; font-size: 12px; color: var(--muted); flex: none; }
.ct-chev { color: var(--muted); font-size: 22px; transition: transform .18s; flex: none; }
.combo.open .ct-chev { transform: rotate(180deg); }
.combo-pop { position: absolute; top: calc(100% + 8px); left: 0; right: 0; z-index: 50; background: var(--surface); border: 1px solid var(--line-strong); border-radius: 14px; box-shadow: 0 28px 60px -28px rgba(21, 41, 46, .55); display: none; overflow: hidden; }
.combo.open .combo-pop { display: block; }
.combo-search { position: relative; padding: 10px; border-bottom: 1px solid var(--line); }
.combo-search > .micon { position: absolute; left: 22px; top: 21px; color: var(--muted); font-size: 19px; pointer-events: none; }
.combo-search input { width: 100%; border: 1.5px solid var(--line-strong); border-radius: 10px; padding: 10px 12px 10px 40px; font: inherit; font-size: 14.5px; color: var(--ink); background: var(--surface); }
.combo-search input:focus { outline: 2px solid var(--accent); outline-offset: 1px; border-color: var(--accent); }
.combo-list { max-height: 342px; overflow: auto; padding: 6px; }
.cl-head { display: flex; align-items: center; gap: 6px; font-family: "IBM Plex Mono", monospace; font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); padding: 9px 12px 5px; }
.cl-head .micon { font-size: 14px; color: var(--spark); }
.ir { display: flex; align-items: center; gap: 11px; padding: 9px 12px; border-radius: 9px; cursor: pointer; transition: .12s; color: inherit; text-decoration: none; }
.ir:hover { background: var(--surface-2); }
.ir.active { background: var(--accent-soft); }
.ir .dir { font-size: 15px; color: var(--muted); flex: none; }
.ir .irn { font-weight: 600; font-size: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ir .iru { font-family: "IBM Plex Mono", monospace; font-size: 11px; color: var(--muted); margin-left: auto; flex: none; }
.ir .star { color: var(--line-strong); font-size: 19px; flex: none; }
.ir .star:hover { color: var(--spark); }
.ir .star.on { color: var(--spark); }
.ir.nd .irn, .ir.nd .iru, .ir.nd .dir { opacity: .45; }
.ir-empty { padding: 16px; color: var(--muted); font-size: 13.5px; text-align: center; }
.ir-more { padding: 9px 12px; font-family: "IBM Plex Mono", monospace; font-size: 11.5px; color: var(--muted); }
