/* ham-tools.css — styles des outils radioamateur (balises, conditions de bandes, CW).
   Réutilise les tokens de thème et le shell (.container/.panel/header) de sat-tools.css. */

/* ░░ Commun ░░ */
.loc-err { color: var(--red); font-size: 11px; }

/* ░░ BALISES NCDXF (/beacons) ░░ */
.beacon-now {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}
@media (max-width: 760px) { .beacon-now { grid-template-columns: repeat(2, 1fr); } }
.bn-card {
  border: 1px solid var(--border);
  border-top: 3px solid var(--bc, var(--accent));
  border-radius: 3px;
  padding: 10px;
  background: var(--bg);
  cursor: pointer;
  transition: background 0.15s, transform 0.08s;
}
.bn-card:hover { background: var(--accent-soft); }
.bn-card:active { transform: scale(0.99); }
.bn-band {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.12em;
  color: var(--bc, var(--accent)); text-transform: uppercase;
}
.bn-band span { color: var(--text-muted); }
.bn-call { font-family: 'Orbitron', sans-serif; font-size: 19px; font-weight: 700; color: var(--text); margin: 4px 0 2px; }
.bn-qth { font-size: 11px; color: var(--text-dim); min-height: 14px; }
.bn-ad { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-muted); margin-top: 4px; min-height: 13px; }
.bn-bar { height: 4px; background: var(--panel-2); border-radius: 2px; overflow: hidden; margin-top: 8px; }
.bn-bar i { display: block; height: 100%; background: var(--bc, var(--accent)); }
.bn-pow { display: flex; gap: 3px; margin-top: 8px; flex-wrap: wrap; }
.pip { font-family: 'JetBrains Mono', monospace; font-size: 8.5px; padding: 1px 4px; border-radius: 2px;
  border: 1px solid var(--border); color: var(--text-muted); white-space: nowrap; }
.pip.on { background: var(--bc, var(--accent)); color: var(--bg); border-color: var(--bc, var(--accent)); font-weight: 700; }

.bc-layout { display: flex; flex-direction: column; gap: 14px; margin-top: 14px; }

/* Séquence par bande */
.seq-row { display: flex; align-items: center; gap: 10px; padding: 6px 0; border-bottom: 1px solid var(--td-border); }
.seq-row:last-child { border-bottom: none; }
.seq-band { flex: 0 0 auto; width: 58px; display: flex; flex-direction: column; line-height: 1.1;
  font-family: 'JetBrains Mono', monospace; font-weight: 700; font-size: 13px; color: var(--bc, var(--accent)); }
.seq-band small { color: var(--text-muted); font-weight: 400; font-size: 8.5px; letter-spacing: 0; }
.seq-track { display: flex; gap: 5px; flex: 1 1 auto; overflow: hidden; }
.seq-chip { flex: 0 0 auto; font-family: 'JetBrains Mono', monospace; font-size: 11px; padding: 4px 7px;
  border-radius: 3px; background: var(--bg); border: 1px solid var(--border); color: var(--text-muted); white-space: nowrap; }
.seq-chip:nth-child(n+5) { opacity: 0.6; }   /* passages lointains estompés */
.seq-chip.now { background: var(--bc, var(--accent)); color: var(--bg); border-color: var(--bc, var(--accent)); font-weight: 700; opacity: 1; }
.seq-chip.now i { font-style: normal; margin-left: 6px; font-size: 9px; opacity: 0.85; }

#beacon-map { width: 100%; max-width: 880px; margin: 0 auto; height: auto; aspect-ratio: 2 / 1; display: block; border: 1px solid var(--border); border-radius: 3px; }
.bc-help { font-size: 11px; color: var(--text-muted); line-height: 1.5; margin-top: 10px; }

/* ░░ CONDITIONS DE BANDES (/bands) ░░ */
.mini-btn { background: var(--bg); border: 1px solid var(--border-strong); color: var(--text-dim);
  border-radius: 2px; cursor: pointer; padding: 1px 7px; font-size: 13px; }
.mini-btn:hover { color: var(--accent); border-color: var(--accent); }

.idx-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
@media (max-width: 900px) { .idx-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .idx-grid { grid-template-columns: 1fr; } }
.idx-card { border: 1px solid var(--border); border-radius: 3px; padding: 10px; background: var(--bg); }
.idx-title { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--text-muted); }
.idx-value { font-family: 'Orbitron', sans-serif; font-size: 24px; font-weight: 700; color: var(--text);
  margin: 4px 0 2px; display: flex; align-items: baseline; gap: 6px; }
.idx-value .u { font-size: 11px; color: var(--text-muted); font-weight: 400; }
.idx-scale { font-family: 'JetBrains Mono', monospace; font-size: 10px; padding: 1px 6px; border-radius: 2px;
  background: var(--panel-2); font-weight: 600; margin-left: auto; }
.idx-label { font-size: 12px; font-weight: 600; text-transform: capitalize; }
.idx-note { font-size: 10.5px; color: var(--text-muted); line-height: 1.45; margin-top: 5px; }
.idx-value.good, .idx-label.good, .idx-scale.good { color: var(--green); }
.idx-value.fair, .idx-label.fair, .idx-scale.fair { color: var(--warn); }
.idx-value.poor, .idx-label.poor, .idx-scale.poor { color: var(--red); }

.bands-layout { display: grid; grid-template-columns: 1.2fr 1fr; gap: 14px; margin-top: 14px; align-items: start; }
@media (max-width: 900px) { .bands-layout { grid-template-columns: 1fr; } }

.daynight { display: flex; align-items: baseline; gap: 10px; margin-bottom: 12px; }
.dn { font-family: 'Orbitron', sans-serif; font-size: 16px; font-weight: 700; letter-spacing: 0.06em; }
.dn.day { color: var(--warn); } .dn.night { color: var(--accent); }
.dn .gray { color: var(--cyan); font-size: 11px; }
.dn-sub { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-muted); }

.hf-table { width: 100%; border-collapse: collapse; }
.hf-table th { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--text-muted); padding: 6px; border-bottom: 1px solid var(--border); text-align: center; }
.hf-table th:first-child { text-align: left; }
.hf-table th.now { color: var(--accent); }
.hf-table td { padding: 8px 6px; border-bottom: 1px solid var(--td-border); }
.hf-band b { display: block; color: var(--text); font-size: 13px; }
.hf-band span { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-muted); }
.cond { text-align: center; font-weight: 600; font-size: 13px; border-radius: 2px; }
.cond.good { color: var(--green); } .cond.fair { color: var(--warn); } .cond.poor { color: var(--red); }
.cond.now { box-shadow: inset 0 0 0 1px var(--accent); background: var(--accent-soft); }

.best-bands { margin-top: 14px; display: flex; flex-direction: column; gap: 6px; }
.bb-line { font-size: 13px; padding: 8px 10px; border-radius: 3px; border-left: 3px solid; background: var(--bg); }
.bb-line.good { border-color: var(--green); } .bb-line.fair { border-color: var(--warn); } .bb-line.poor { border-color: var(--red); }
.bb-tag { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--text-muted); margin-right: 8px; }

.vhf-item { display: flex; justify-content: space-between; align-items: center; padding: 8px 4px; border-bottom: 1px solid var(--td-border); }
.vhf-lbl { font-size: 12px; color: var(--text-dim); }
.vhf-val { font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 600; }
.vhf-val.good { color: var(--green); } .vhf-val.fair { color: var(--warn); } .vhf-val.poor { color: var(--text-muted); }

/* ░░ ENTRAÎNEUR CW (/cw) ░░ */
.cw-layout { display: grid; grid-template-columns: 1.4fr 1fr; gap: 14px; align-items: start; }
@media (max-width: 980px) { .cw-layout { grid-template-columns: 1fr; } }
.cw-main, .cw-side { display: flex; flex-direction: column; gap: 14px; }

.mode-tabs { display: inline-flex; border: 1px solid var(--border); border-radius: 2px; overflow: hidden; }
.mode-tab { background: transparent; color: var(--text-muted); border: none; border-right: 1px solid var(--border);
  padding: 3px 10px; font-family: 'JetBrains Mono', monospace; font-size: 10px; cursor: pointer; }
.mode-tab:last-child { border-right: none; }
.mode-tab.active { background: var(--accent); color: var(--bg); }

.koch-ctl { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; font-size: 12px; color: var(--text-dim); }
.koch-progress { flex: 1 1 100%; }
.kp-bar { height: 8px; background: var(--panel-2); border-radius: 4px; overflow: hidden; }
.kp-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--green-dim), var(--green)); }
.kp-meta { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-muted); margin-top: 5px; }
.kp-chars { color: var(--green); letter-spacing: 0.15em; }

.cw-progress-wrap { height: 5px; background: var(--panel-2); border-radius: 3px; overflow: hidden; margin: 6px 0 12px; }
.cw-progress-bar { height: 100%; width: 0; background: var(--accent); transition: width 0.1s linear; }

.cw-buttons { display: flex; gap: 8px; flex-wrap: wrap; }
.cw-buttons button { padding: 8px 12px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.06em;
  cursor: pointer; border: 1px solid var(--border-strong); border-radius: 2px; background: var(--bg); color: var(--text-dim); }
.cw-buttons button:disabled { opacity: 0.4; cursor: default; }
.cw-buttons .primary { background: var(--accent); color: var(--bg); border-color: var(--accent); }

.cw-input-lbl { display: block; font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-muted); margin: 14px 0 4px; }
.cw-input { width: 100%; background: var(--bg); border: 1px solid var(--border-strong); border-radius: 3px;
  color: var(--green); font-family: 'JetBrains Mono', monospace; font-size: 18px; letter-spacing: 0.18em; padding: 8px 10px; resize: vertical; }
.cw-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 2px var(--input-glow); }

.cw-results { margin-top: 14px; }
.cw-score { font-family: 'Orbitron', sans-serif; font-size: 34px; font-weight: 700; display: flex; align-items: baseline; gap: 12px; }
.cw-score span { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--text-muted); }
.cw-score.good { color: var(--green); } .cw-score.fair { color: var(--warn); } .cw-score.poor { color: var(--red); }
.cw-levelup { margin: 8px 0; padding: 8px 10px; border-left: 3px solid var(--green); background: var(--callsign-bg); font-size: 13px; color: var(--green); }
.cw-diff { font-family: 'JetBrains Mono', monospace; font-size: 18px; letter-spacing: 0.1em; margin-top: 10px; line-height: 1.8; }
.dc { position: relative; }
.dc.ok { color: var(--green); }
.dc.bad { color: var(--red); } .dc.bad i { font-style: normal; font-size: 10px; color: var(--warn); vertical-align: super; }
.dc.miss { color: var(--text-muted); } .dc.miss i { font-style: normal; color: var(--red); }
.dc-sp { display: inline-block; width: 12px; }
.cw-reveal-wrap { margin-top: 12px; font-size: 12px; color: var(--text-muted); }
#cw-reveal { color: var(--text-dim); font-family: 'JetBrains Mono', monospace; letter-spacing: 0.12em; }

.char-heatmap { display: grid; grid-template-columns: repeat(auto-fill, minmax(46px, 1fr)); gap: 5px; }
.hm-cell { border: 1px solid var(--border); border-radius: 3px; padding: 5px 2px; text-align: center; cursor: pointer; background: var(--bg); }
.hm-cell .hm-ch { display: block; font-family: 'Orbitron', sans-serif; font-weight: 700; font-size: 15px; color: var(--text); }
.hm-cell .hm-code { display: block; font-family: 'JetBrains Mono', monospace; font-size: 9px; color: var(--text-muted); margin-top: 1px; }
.hm-cell.m-good { border-color: var(--green-dim); background: rgba(77,255,167,0.08); }
.hm-cell.m-fair { border-color: var(--warn); background: rgba(251,191,36,0.08); }
.hm-cell.m-poor { border-color: var(--red); background: rgba(239,68,68,0.08); }
.hm-cell.locked { opacity: 0.35; cursor: default; }
.hm-cell.locked .hm-ch { color: var(--text-muted); }
.weak-chars { margin-top: 10px; font-size: 12px; color: var(--text-dim); }
.weak-chars b { color: var(--warn); }
.hm-legend { display: flex; flex-wrap: wrap; gap: 4px 12px; margin-top: 10px; font-size: 10px; color: var(--text-muted); }
.hm-legend span { display: inline-flex; align-items: center; gap: 4px; }
.hm-legend i { width: 10px; height: 10px; border-radius: 2px; border: 1px solid var(--border); display: inline-block; }
.hm-legend i.m-good { border-color: var(--green-dim); background: rgba(77,255,167,0.2); }
.hm-legend i.m-fair { border-color: var(--warn); background: rgba(251,191,36,0.2); }
.hm-legend i.m-poor { border-color: var(--red); background: rgba(239,68,68,0.2); }
.hm-legend i.locked { opacity: 0.4; }

.set-row { margin-bottom: 12px; }
.set-row label { display: block; font-size: 11px; color: var(--text-dim); margin-bottom: 4px; }
.set-row label b { color: var(--accent); }
.set-row input[type=range] { width: 100%; }

.cw-globals { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 12px; }
.cw-globals .g { border: 1px solid var(--border); border-radius: 3px; padding: 8px; background: var(--bg); }
.cw-globals .k { display: block; font-size: 9px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted); }
.cw-globals .v { font-family: 'Orbitron', sans-serif; font-size: 18px; font-weight: 700; color: var(--accent); }

.cw-hist-table { width: 100%; border-collapse: collapse; font-family: 'JetBrains Mono', monospace; font-size: 10.5px; }
.cw-hist-table th { text-align: left; color: var(--text-muted); font-weight: 500; font-size: 9px; text-transform: uppercase;
  padding: 4px; border-bottom: 1px solid var(--border); }
.cw-hist-table td { padding: 3px 4px; border-bottom: 1px solid var(--td-border); color: var(--text-dim); }
.cw-hist-table td.ok { color: var(--green); } .cw-hist-table td.fair { color: var(--warn); } .cw-hist-table td.bad { color: var(--red); }
.cw-empty { color: var(--text-muted); text-align: center; }
.cw-io { display: flex; gap: 8px; margin-top: 10px; }
.mini-btn.danger:hover { color: var(--red); border-color: var(--red); }

/* ░░ CARTE DE PROPAGATION (/bands) ░░ */
.prop-bands { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.pb-chip { font-family: 'JetBrains Mono', monospace; font-size: 11px; padding: 3px 11px; border-radius: 2px;
  border: 1px solid var(--border); background: var(--bg); color: var(--text-dim); cursor: pointer; }
.pb-chip:hover { color: var(--text); border-color: var(--border-strong); }
.pb-chip.active { background: var(--accent); color: var(--bg); border-color: var(--accent); font-weight: 600; }

.prop-map-wrap { border: 1px solid var(--border); border-radius: 3px; overflow: hidden; }
#prop-map { width: 100%; height: 460px; }
.leaflet-container { background: #0a1426; font-family: 'JetBrains Mono', monospace; font-size: 11px; }
.leaflet-control-attribution { background: rgba(13,18,32,0.8) !important; color: var(--text-muted) !important; }
.leaflet-control-attribution a { color: var(--cyan) !important; }
.leaflet-tooltip.dx-tip { background: var(--panel); color: var(--text); border: 1px solid var(--border-strong);
  font-family: 'JetBrains Mono', monospace; font-size: 11px; box-shadow: none; }
.leaflet-tooltip.dx-tip::before { display: none; }

.prop-legend { display: flex; flex-wrap: wrap; gap: 6px 16px; margin-top: 8px; font-size: 10.5px; color: var(--text-muted); }
.prop-legend span { display: inline-flex; align-items: center; gap: 6px; }
.prop-legend i { display: inline-block; }
.prop-legend .lg-blob { width: 12px; height: 12px; border-radius: 50%; background: radial-gradient(var(--green), transparent 70%); }
.prop-legend .lg-line { width: 16px; height: 0; border-top: 1px solid var(--cyan); }
.prop-legend .lg-gray { width: 16px; height: 0; border-top: 1px dashed var(--warn); }
.prop-legend .lg-iono { width: 16px; height: 0; border-top: 2px solid #d65f8a; }
.prop-legend .lg-sp { width: 16px; height: 0; border-top: 2px solid #4dffa7; }
.prop-legend .lg-lp { width: 16px; height: 0; border-top: 2px dashed #4dffa7; }

.prop-analysis { margin-top: 14px; }
.pa-head, .pa-row { display: grid; grid-template-columns: 48px 1fr 44px 78px 92px; gap: 8px; align-items: center; }
.pa-head { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--text-muted); padding-bottom: 6px; border-bottom: 1px solid var(--border); }
.pa-row { padding: 5px 0; border-bottom: 1px solid var(--td-border); font-family: 'JetBrains Mono', monospace; font-size: 11px; }
.pa-band { font-weight: 700; }
.pa-bar { background: var(--panel-2); height: 8px; border-radius: 4px; overflow: hidden; }
.pa-bar i { display: block; height: 100%; }
.pa-cnt { text-align: right; color: var(--text-dim); }
.pa-model.good { color: var(--green); } .pa-model.fair { color: var(--warn); } .pa-model.poor { color: var(--red); } .pa-model { color: var(--text-muted); }
.pa-verdict { font-weight: 600; }
.pa-verdict.good { color: var(--green); } .pa-verdict.fair { color: var(--warn); } .pa-verdict.poor { color: var(--text-muted); }
@media (max-width: 620px) {
  .pa-head { display: none; }
  .pa-row { grid-template-columns: 40px 1fr 36px; }
  .pa-row .pa-model, .pa-row .pa-verdict { display: none; }
}

/* ░░ STATION SDR (/station) ░░ */
.sdr-status { display: flex; align-items: center; gap: 16px; padding: 8px 0 18px; }
.sdr-led { width: 22px; height: 22px; border-radius: 50%; flex: 0 0 auto; position: relative; }
.sdr-led::after { content: ''; position: absolute; inset: -5px; border-radius: 50%; opacity: 0.35; }
.sdr-led.online { background: var(--green); box-shadow: 0 0 12px var(--green); }
.sdr-led.online::after { background: var(--green); animation: sdr-pulse 1.8s ease-out infinite; }
.sdr-led.busy { background: var(--warn); box-shadow: 0 0 12px var(--warn); }
.sdr-led.offline { background: var(--text-muted); }
@keyframes sdr-pulse { 0% { transform: scale(0.8); opacity: 0.5; } 100% { transform: scale(1.8); opacity: 0; } }
.sdr-state-main { font-family: 'Orbitron', sans-serif; font-size: 26px; font-weight: 700; letter-spacing: 0.05em; color: var(--text); }
.sdr-state-main.online { color: var(--green); }
.sdr-state-main.busy { color: var(--warn); }
.sdr-state-main.offline { color: var(--text-muted); }
.sdr-state-sub { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--text-muted); margin-top: 3px; }

.sdr-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
@media (max-width: 720px) { .sdr-grid { grid-template-columns: repeat(2, 1fr); } }
.sdr-card { border: 1px solid var(--border); border-radius: 3px; padding: 10px; background: var(--bg); }
.sdr-card .k { display: block; font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--text-muted); }
.sdr-card .v { font-family: 'JetBrains Mono', monospace; font-size: 14px; color: var(--text); font-weight: 600; word-break: break-all; }
.sdr-listen { display: inline-block; text-decoration: none; padding: 10px 16px; }

/* ░░ PANADAPTER (/station privé) ░░ */
.pan-status.ok { color: var(--green); } .pan-status.warn { color: var(--warn); } .pan-status.err { color: var(--red); }
.pan-ctl { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin-bottom: 10px; }
.pan-ctl .primary { background: var(--accent); color: var(--bg); border: 1px solid var(--accent); border-radius: 2px;
  padding: 7px 14px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.06em; cursor: pointer; }
.pan-bands { display: inline-flex; flex-wrap: wrap; gap: 3px; }
.pan-bands button { background: var(--bg); border: 1px solid var(--border); color: var(--text-dim);
  border-radius: 2px; padding: 4px 8px; font-family: 'JetBrains Mono', monospace; font-size: 10px; cursor: pointer; }
.pan-bands button:hover { color: var(--accent); border-color: var(--accent); }
.pan-fld { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); display: inline-flex; align-items: center; gap: 5px; }
.pan-fld input { width: 78px; }
.pan-readout { display: flex; flex-wrap: wrap; gap: 16px; font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--text-muted); margin-bottom: 8px; }
.pan-readout b { color: var(--accent); }
.pan-edges { color: var(--text-dim); }
#pan-canvas { width: 100%; height: 360px; display: block; border: 1px solid var(--border); border-radius: 3px;
  background: #0a1020; cursor: crosshair; }

/* Panadapter — audio, S-mètre, marqueurs, mémoires */
.pan-audio-ctl, .pan-wf-ctl { margin-top: 8px; }
#pan-audio { background: var(--bg); border: 1px solid var(--border-strong); color: var(--text-dim);
  border-radius: 2px; padding: 5px 12px; font-family: 'JetBrains Mono', monospace; font-size: 11px; cursor: pointer; }
#pan-audio[aria-pressed="true"] { color: var(--green); border-color: var(--green); }
.pan-mk { display: inline-flex; gap: 10px; font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-dim); }
.pan-mk label { display: inline-flex; align-items: center; gap: 3px; cursor: pointer; }
.pan-smeter { display: inline-block; width: 110px; height: 9px; background: var(--panel-2);
  border: 1px solid var(--border); border-radius: 4px; overflow: hidden; vertical-align: middle; }
.pan-smeter i { display: block; height: 100%; width: 0;
  background: linear-gradient(90deg, var(--green-dim), var(--green) 55%, var(--warn) 78%, var(--red)); transition: width 0.12s; }
#pan-smeter-txt { color: var(--accent); margin-left: 2px; }
.pan-wf-ctl .pan-fld input[type=range] { width: 90px; }
.pan-mem { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin-top: 10px; }
.pan-mem-list { display: inline-flex; flex-wrap: wrap; gap: 5px; }
.mem-chip { font-family: 'JetBrains Mono', monospace; font-size: 10px; padding: 3px 7px; border-radius: 2px;
  background: var(--bg); border: 1px solid var(--border); color: var(--text-dim); cursor: pointer; }
.mem-chip:hover { border-color: var(--accent); color: var(--text); }
.mem-chip b { color: var(--text-muted); margin-left: 5px; cursor: pointer; }
.mem-chip b:hover { color: var(--red); }
.mem-empty { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-muted); }

/* ░░ ANALYSE WSPR (/wspr) ░░ */
.src-tabs { display: inline-flex; border: 1px solid var(--border); border-radius: 2px; overflow: hidden; }
.src-tabs .src-tab { background: transparent; color: var(--text-muted); border: none; border-right: 1px solid var(--border);
  padding: 4px 10px; font-family: 'JetBrains Mono', monospace; font-size: 10px; cursor: pointer; }
.src-tabs .src-tab:last-child { border-right: none; }
.src-tabs .src-tab.active { background: var(--accent); color: var(--bg); }

.wb-head, .wb-row { display: grid; grid-template-columns: 52px 1fr 54px 56px 180px 70px 90px; gap: 8px; align-items: center; }
.wb-head { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--text-muted); padding-bottom: 6px; border-bottom: 1px solid var(--border); }
.wb-row { padding: 5px 0; border-bottom: 1px solid var(--td-border); font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); }
.wb-band { font-weight: 700; }
.wb-bar { background: var(--panel-2); height: 8px; border-radius: 4px; overflow: hidden; }
.wb-bar i { display: block; height: 100%; }
.wb-spots { text-align: right; color: var(--text); font-weight: 600; }
.wb-reach { text-align: center; font-weight: 600; }
.wb-reach.good { color: var(--green); } .wb-reach.fair { color: var(--warn); } .wb-reach.poor { color: var(--text-muted); }
@media (max-width: 720px) {
  .wb-head { display: none; }
  .wb-row { grid-template-columns: 44px 1fr 48px 80px; }
  .wb-row .wb-rep, .wb-row .wb-snr { display: none; }
  .wb-dist { font-size: 9px; }
}
#wspr-map { width: 100%; height: 440px; }
.wspr-summary { margin: 10px 0; }
.ws-stat { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--text-dim); padding: 8px 10px;
  background: var(--bg); border-left: 3px solid var(--accent); border-radius: 3px; }
.ws-stat b { color: var(--accent); }

/* Sélecteur de source — carte de propagation */
.prop-src { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin-bottom: 8px; }
.prop-src-lbl { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--text-muted); margin-right: 4px; }
.ps-chip, .pi-chip { font-family: 'JetBrains Mono', monospace; font-size: 11px; padding: 3px 11px; border-radius: 2px;
  border: 1px solid var(--border); background: var(--bg); color: var(--text-dim); cursor: pointer; }
.ps-chip:hover, .pi-chip:hover { color: var(--text); border-color: var(--border-strong); }
.ps-chip.active { background: var(--cyan); color: var(--bg); border-color: var(--cyan); font-weight: 600; }
.pi-chip.active { background: #d65f8a; color: var(--bg); border-color: #d65f8a; font-weight: 600; }

/* WSPR page — variante RBN (6 colonnes) */
.wb-head-rbn, .wb-row-rbn { grid-template-columns: 52px 1fr 54px 70px 110px 120px; }
.wspr-rbn-note { color: var(--text-muted); font-size: 11px; }
@media (max-width: 720px) {
  .wb-head-rbn, .wb-row-rbn { grid-template-columns: 44px 1fr 48px 70px; }
  .wb-row-rbn span:nth-child(5), .wb-row-rbn span:nth-child(6) { display: none; }
}

/* ░░ OUVERTURES (/openings) — heatmap bande×heure ░░ */
.oh-grid-wrap { overflow-x: auto; }
#oh-grid { min-width: 560px; }
.oh-row { display: grid; grid-template-columns: 46px repeat(24, 1fr); gap: 2px; align-items: center; margin-bottom: 2px; }
.oh-hdr .oh-h { font-family: 'JetBrains Mono', monospace; font-size: 8px; color: var(--text-muted); text-align: center; }
.oh-band { font-family: 'JetBrains Mono', monospace; font-weight: 700; font-size: 11px; }
.oh-cell { height: 16px; border-radius: 1px; cursor: pointer; background: transparent; }
.oh-cell:hover { outline: 1px solid var(--text); }
.oh-summary { margin-top: 14px; font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); line-height: 1.8; }
.oh-summary b { color: var(--text); }
.oh-hourctl { display: flex; align-items: center; gap: 10px; margin: 6px 0 10px; font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); }
.oh-hourctl input[type=range] { flex: 1 1 auto; max-width: 420px; }
#oh-map { width: 100%; height: 440px; }
