Files
trx-rs/src/trx-client/trx-frontend/trx-frontend-http/assets/web/style.css
T
2026-03-24 20:52:01 +01:00

4262 lines
112 KiB
CSS

:root {
--bg: #070d1a;
--card-bg: #0f172a;
--input-bg: #0b1324;
--border: #22324a;
--border-light: #304766;
--text: #e7edf9;
--text-muted: #91a3bd;
--text-heading: #c6d5ea;
--btn-bg: #16243a;
--btn-border: #3a5274;
--accent-green: #c24b1a;
--accent-yellow: #f0ad4e;
--accent-red: #e55353;
--vchan-color: #38bdf8;
--control-height: 2.6rem;
--jog-hi: #243a5b;
--jog-lo: #14233a;
--jog-shadow: rgba(0,0,0,0.3);
--jog-inset: rgba(255,255,255,0.05);
--audio-level-bg: #14263f;
--audio-level-border: #304766;
--audio-level-fill-start: #c24b1a;
--audio-level-fill-end: #f0ad4e;
--filter-bg: #13253e;
--filter-fg: #e7edf9;
--filter-border: #385577;
--wavelength-fg: #8da3be;
--spectrum-bg: #0a0f18;
--overview-plot-height: 160px;
--spectrum-plot-height: 160px;
--jog-wheel-size: 83.2px;
--header-waterfall-overlap: 0rem;
--card-base-max-width: 1280px;
--card-max-width: 1600px;
--card-bookmark-gutter: 9.5rem;
--spectrum-bookmark-side-width: 6.5rem;
--spectrum-bookmark-side-offset: 8.85rem;
}
[data-theme="light"] {
--bg: #edf2f7;
--card-bg: #ffffff;
--input-bg: #f7fafc;
--border: #d6deea;
--border-light: #bcc8da;
--text: #1a202c;
--text-muted: #4a5568;
--text-heading: #2d3748;
--btn-bg: #e6edf8;
--btn-border: #a9b8cf;
--accent-green: #b04317;
--accent-yellow: #b57600;
--accent-red: #cf3f3f;
--jog-hi: #e6edf8;
--jog-lo: #cdd9eb;
--jog-shadow: rgba(58, 79, 110, 0.18);
--jog-inset: rgba(255,255,255,0.75);
--audio-level-bg: #edf2fb;
--audio-level-border: #b8c5da;
--audio-level-fill-start: #b04317;
--audio-level-fill-end: #b57600;
--filter-bg: #eef3fb;
--filter-fg: #1f2937;
--filter-border: #b8c5da;
--wavelength-fg: #6b7280;
--spectrum-bg: #eef3fb;
}
body {
font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
margin: 0;
min-height: 100vh;
min-height: 100dvh;
box-sizing: border-box;
display: block;
background: var(--bg);
color: var(--text);
overflow-x: hidden;
overflow-y: auto;
}
.card {
width: min(100%, var(--card-base-max-width));
margin: 0 auto;
padding: 0.85rem 1.25rem 1.5rem;
background: transparent;
box-sizing: border-box;
min-height: 100vh;
min-height: 100dvh;
display: flex;
flex-direction: column;
overflow: visible;
}
@media (min-width: 1100px) {
.card {
width: min(
var(--card-max-width),
calc(100vw - (var(--card-bookmark-gutter) * 2))
);
}
}
.label { color: var(--text-muted); font-size: 0.9rem; margin-bottom: 6px; display: block; }
#tab-main .label > span {
display: inline-block;
padding: 0.14rem 0.5rem;
border-radius: 999px;
border: 1px solid color-mix(in srgb, var(--border-light) 68%, transparent);
background: color-mix(in srgb, var(--btn-bg) 58%, transparent);
color: var(--text-muted);
font-size: 0.78rem;
font-weight: 700;
letter-spacing: 0.04em;
line-height: 1.2;
}
.status { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.1rem 1rem; }
.controls-tray-shell {
min-width: 0;
}
.controls-tray-scroll {
width: 100%;
min-width: 0;
overflow-x: auto;
overflow-y: hidden;
padding-bottom: 0.2rem;
}
.controls-tray {
display: grid;
gap: 0.95rem;
width: max(100%, 58rem);
min-width: 0;
box-sizing: border-box;
padding: 0.95rem 1rem 1rem;
border: 1px solid color-mix(in srgb, var(--border-light) 85%, transparent);
border-radius: 1rem;
background:
linear-gradient(180deg,
color-mix(in srgb, var(--surface) 88%, transparent),
color-mix(in srgb, var(--btn-bg) 76%, transparent));
box-shadow: inset 0 1px 0 color-mix(in srgb, #ffffff 12%, transparent);
}
input.status-input, select.status-input { width: 100%; padding: 0.45rem 0.5rem; font-size: 1rem; border: 1px solid var(--border-light); border-radius: 6px; background: var(--input-bg); color: var(--text); }
#mode { height: var(--control-height); }
#freq { font-family: 'DSEG14 Classic', monospace; font-size: 2rem; padding: 0.5rem 0.6rem; letter-spacing: 0.05em; text-align: center; }
#freq:disabled,
#center-freq:disabled {
opacity: 1;
-webkit-text-fill-color: currentColor;
}
#center-freq { color: var(--wavelength-fg); }
.controls-row {
display: grid;
grid-template-columns: minmax(0, 1fr) auto auto minmax(0, 1fr);
gap: 1rem;
align-items: start;
}
.controls-col {
min-width: 0;
display: flex;
flex-direction: column;
justify-content: flex-start;
}
.controls-col.label-below-col {
align-items: stretch;
}
.controls-col.label-below-col .label {
order: 2;
margin-top: 0.3rem;
margin-bottom: 0;
}
.controls-col-power.label-below-col .label {
justify-content: flex-end;
}
.controls-col.label-below-col > :not(.label) {
order: 1;
}
.controls-col.label-below-col .inline,
.controls-col.label-below-col .btn-grid {
align-self: stretch;
width: 100%;
margin-top: calc((var(--jog-wheel-size) - var(--control-height)) / 2);
}
.controls-col-center {
justify-self: center;
width: auto;
align-items: center;
}
.controls-col-wfm.label-below-col .label {
justify-content: flex-start;
}
.wfm-controls-inline {
gap: 0.45rem;
justify-content: flex-start;
align-items: flex-end;
flex-wrap: wrap;
}
.wfm-control {
display: flex;
flex-direction: column;
align-items: stretch;
gap: 0.22rem;
color: var(--text-muted);
font-size: 0.72rem;
line-height: 1.1;
white-space: nowrap;
}
.wfm-control-label {
font-size: 0.68rem;
font-weight: 700;
letter-spacing: 0.04em;
text-transform: uppercase;
color: var(--text-muted);
}
.wfm-control .status-input {
min-width: 4.4rem;
width: auto;
height: 2.1rem;
padding: 0.28rem 0.45rem;
font-size: 0.85rem;
line-height: 1.2;
box-sizing: border-box;
}
.wfm-control input.status-input {
width: 4.25rem;
}
.wfm-gain-group {
display: flex;
align-items: flex-end;
gap: 0.35rem;
}
.wfm-inline-btn {
min-width: 3rem;
height: 2.1rem;
padding: 0 0.6rem;
font-size: 0.8rem;
line-height: 1.1;
flex-shrink: 0;
}
.wfm-st-flag-wrap {
min-width: 0;
}
.wfm-st-flag {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 2.7rem;
min-height: 2.1rem;
padding: 0.28rem 0.5rem;
box-sizing: border-box;
border: 1px solid var(--border-light);
border-radius: 6px;
font-size: 0.82rem;
font-weight: 800;
line-height: 1.2;
letter-spacing: 0.04em;
background: var(--input-bg);
}
.wfm-st-flag-stereo {
color: #ff5c5c;
border-color: color-mix(in srgb, #ff5c5c 65%, var(--border-light));
background: color-mix(in srgb, #ff5c5c 14%, var(--input-bg));
}
.wfm-st-flag-mono {
color: var(--text-muted);
border-color: var(--border-light);
background: color-mix(in srgb, var(--input-bg) 92%, var(--panel-2));
}
.controls-col-center::after {
content: "";
display: block;
min-height: 1.2rem;
margin-top: 0.3rem;
}
.controls-row .label {
margin-bottom: 6px;
margin-top: 0;
min-height: 1.2rem;
display: flex;
align-items: center;
white-space: nowrap;
}
.controls-col .inline,
.controls-col .btn-grid {
align-self: stretch;
}
.controls-col .jog-container { align-self: center; }
.btn-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 0.5rem;
}
.btn-grid button { width: 100%; height: var(--control-height); }
.jog-container {
display: flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
}
.jog-wheel {
width: var(--jog-wheel-size);
height: var(--jog-wheel-size);
border-radius: 50%;
background: radial-gradient(circle at 40% 35%, var(--jog-hi), var(--jog-lo));
border: 2px solid var(--border-light);
position: relative;
cursor: grab;
flex-shrink: 0;
box-shadow: 0 2px 8px var(--jog-shadow), inset 0 1px 0 var(--jog-inset);
user-select: none;
-webkit-user-select: none;
touch-action: none;
}
.jog-indicator {
position: absolute;
width: 6.4px;
height: 16px;
background: var(--accent-green);
border-radius: 2px;
top: 6.4px;
left: 50%;
transform-origin: 50% 35.2px;
transform: translateX(-50%);
pointer-events: none;
}
.jog-btn {
width: 3.3rem;
height: 3.3rem;
font-size: 1.8rem;
padding: 0;
display: flex;
align-items: center;
justify-content: center;
border-radius: 50%;
flex-shrink: 0;
}
.jog-step {
display: flex;
border: 1px solid var(--border-light);
border-radius: 6px;
overflow: hidden;
height: 3.35rem;
flex-shrink: 0;
}
.jog-step button {
border: none;
border-right: 1px solid var(--border-light);
border-radius: 0;
height: 100%;
padding: 0 0.65rem;
font-size: 0.92rem;
background: var(--input-bg);
color: var(--text-muted);
cursor: pointer;
}
.jog-step button:last-child { border-right: none; }
.jog-step button.active {
background: var(--btn-bg);
color: var(--accent-green);
font-weight: 600;
}
.vfo-picker {
display: flex;
border: 1px solid var(--border-light);
border-radius: 6px;
overflow: hidden;
}
.vfo-picker button {
flex: 1;
border: none;
border-right: 1px solid var(--border-light);
border-radius: 0;
height: var(--control-height);
background: var(--input-bg);
color: var(--text-muted);
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
font-size: 0.85rem;
}
.vfo-picker button:last-child { border-right: none; }
.vfo-picker button.active {
background: var(--btn-bg);
font-weight: 600;
}
.channel-scheduler-controls {
display: flex;
flex-wrap: wrap;
align-items: flex-start;
gap: 0.6rem 0.8rem;
}
.vchan-picker {
display: flex;
flex-wrap: wrap;
gap: 4px;
flex: 1 1 18rem;
min-width: 0;
}
.scheduler-control-row {
display: flex;
align-items: flex-start;
justify-content: flex-start;
flex: 0 1 22rem;
}
.scheduler-release-wrap {
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 0.35rem;
min-width: 14rem;
}
.scheduler-release-wrap button.active {
border-color: var(--accent-yellow);
color: var(--accent-yellow);
}
.scheduler-step-controls {
display: flex;
flex-wrap: wrap;
gap: 0.35rem;
}
.scheduler-step-controls button {
min-width: 7.6rem;
}
.scheduler-release-status {
color: var(--text-muted);
font-size: 0.78rem;
text-align: left;
}
.scheduler-cycle-status {
color: var(--text-muted);
font-size: 0.74rem;
text-align: left;
opacity: 0.88;
}
.vchan-picker button {
display: inline-flex;
align-items: center;
gap: 4px;
border: 1px solid var(--border-light);
border-radius: 6px;
height: var(--control-height);
padding: 0 0.55rem;
background: var(--input-bg);
color: var(--text-muted);
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
font-size: 0.82rem;
cursor: pointer;
}
.vchan-picker button.active {
background: var(--btn-bg);
color: var(--text);
font-weight: 600;
border-color: var(--vchan-color);
box-shadow: inset 3px 0 0 var(--vchan-color);
}
/* Applied to #freq and #spectrum-bw-input when on a virtual channel */
.vchan-ch-active {
border-color: var(--vchan-color) !important;
box-shadow: 0 0 0 1px var(--vchan-color);
}
.vchan-del {
opacity: 0.5;
font-size: 1rem;
line-height: 1;
}
.vchan-del:hover { opacity: 1; }
.vchan-add {
font-size: 1.1rem;
font-weight: 700;
padding: 0 0.6rem !important;
color: var(--text-muted);
}
.signal-measure {
display: inline-flex;
gap: 0.5rem;
align-items: center;
margin-top: 0.4rem;
}
button { padding: 0.5rem 0.9rem; border-radius: 6px; border: 1px solid var(--btn-border); background: var(--btn-bg); color: var(--text); cursor: pointer; height: var(--control-height); transition: background 100ms ease, border-color 100ms ease, color 100ms ease, box-shadow 100ms ease; }
button:hover:not(:disabled) { background: color-mix(in srgb, var(--btn-bg) 75%, var(--accent-green)); border-color: color-mix(in srgb, var(--btn-border) 60%, var(--accent-green)); box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent-green) 18%, transparent); }
button:active:not(:disabled) { background: color-mix(in srgb, var(--btn-bg) 55%, var(--accent-green)); border-color: var(--accent-green); box-shadow: none; transform: translateY(1px); }
button:disabled { opacity: 0.6; cursor: not-allowed; }
.hint { color: var(--text-muted); font-size: 0.85rem; }
.inline { display: flex; gap: 0.5rem; align-items: center; }
.freq-inline {
gap: 0.35rem;
align-items: flex-start;
flex-wrap: nowrap;
}
.freq-field {
display: grid;
grid-template-rows: 3.35rem auto;
align-items: start;
}
.freq-field .label {
margin-top: 0.45rem;
margin-bottom: 0;
}
.frequency-col {
flex: 1 1 auto;
min-width: 0;
}
.center-frequency-col {
flex: 0 1 8.75rem;
min-width: 7.75rem;
}
.frequency-col input.status-input {
width: 100%;
height: 3.35rem;
box-sizing: border-box;
}
.wavelength-col {
flex: 0 0 auto;
}
.unit-col {
flex: 0 0 auto;
}
.unit-col .label {
display: flex;
justify-content: flex-end;
}
.mult-col {
flex: 0 0 auto;
}
.mult-col .label {
display: flex;
justify-content: flex-end;
}
.jog-mult {
display: inline-grid;
grid-template-columns: repeat(2, minmax(0, auto));
border: 1px solid var(--border-light);
border-radius: 6px;
overflow: hidden;
height: 3.35rem;
flex-shrink: 0;
width: auto;
}
.jog-mult button {
min-width: 3.15rem;
border: none;
border-right: 1px solid var(--border-light);
border-radius: 0;
height: 100%;
padding: 0 0.7rem;
font-size: 0.85rem;
background: var(--input-bg);
color: var(--text-muted);
cursor: pointer;
}
.jog-mult button:last-child { border-right: none; }
.jog-mult button.active {
background: var(--btn-bg);
color: var(--accent-green);
font-weight: 600;
}
.label-below-row {
display: flex;
flex-direction: column;
}
#tab-main .label > span {
text-align: center;
}
.label-below-row > .label {
order: 2;
margin-top: 0.45rem;
margin-bottom: 0;
}
.label-below-row > :not(.label) {
order: 1;
}
.wavelength-display {
min-width: 5.2rem;
height: 3.35rem;
padding: 0 0.7rem;
border: 1px solid var(--border-light);
border-radius: 6px;
background: var(--input-bg);
color: var(--wavelength-fg);
display: inline-flex;
align-items: center;
justify-content: center;
font-family: 'DSEG14 Classic', monospace;
font-weight: 600;
font-size: 1.25rem;
letter-spacing: 0.03em;
white-space: nowrap;
flex-shrink: 0;
}
small { color: var(--text-muted); }
.header {
margin-bottom: 0;
padding: 0.25rem 0 0.15rem;
position: relative;
z-index: 6;
}
.header-main {
display: inline-flex;
align-items: center;
gap: 0.9rem;
max-width: min(100%, 46rem);
padding: 0.35rem 0.8rem 0.4rem 0.45rem;
margin-left: -0.3rem;
transform: translateY(-10px);
border-radius: 0.95rem;
background: color-mix(in srgb, var(--card-bg) 56%, transparent);
backdrop-filter: blur(12px) saturate(125%);
-webkit-backdrop-filter: blur(12px) saturate(125%);
box-shadow:
0 8px 20px color-mix(in srgb, #000000 18%, transparent),
inset 0 1px 0 color-mix(in srgb, #ffffff 10%, transparent);
}
.header-text {
width: auto;
min-width: 0;
flex: 0 1 auto;
}
.title { font-size: 1.4rem; font-weight: 700; display: inline-flex; align-items: center; gap: 0.35rem; }
.title-link {
color: inherit;
text-decoration: none;
}
.title-link:hover {
text-decoration: underline;
text-underline-offset: 0.14em;
}
.overview-strip {
width: 100%;
margin: 0;
position: relative;
}
.signal-visual-block {
position: relative;
display: flex;
flex-direction: column;
gap: 0;
margin-bottom: 0.9rem;
}
#signal-split-control {
position: absolute;
top: 50%;
right: 0.32rem;
transform: translateY(-50%);
z-index: 9;
display: none;
flex-direction: column;
align-items: center;
gap: 0.24rem;
padding: 0.24rem 0.2rem;
border: 1px solid var(--btn-border);
border-radius: 6px;
background: var(--btn-bg);
box-shadow: inset 0 1px 0 color-mix(in srgb, #ffffff 6%, transparent);
}
#signal-split-slider {
writing-mode: vertical-lr;
direction: rtl;
width: 0.5rem;
height: 5.4rem;
margin: 0;
accent-color: var(--accent-green);
cursor: ns-resize;
}
#signal-split-value {
min-width: 2.4rem;
text-align: center;
font-size: 0.6rem;
font-weight: 600;
letter-spacing: 0.03em;
color: var(--text);
}
#signal-overlay-canvas {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 0;
pointer-events: none;
z-index: 4;
}
#fast-freq-marker {
display: none;
position: absolute;
top: 0;
left: 0;
width: 2px;
height: 100%;
background: #ff1744;
opacity: 0.85;
pointer-events: none;
z-index: 5;
will-change: transform;
}
#fast-bw-left, #fast-bw-right {
display: none;
position: absolute;
top: 0;
left: 0;
height: 100%;
pointer-events: none;
z-index: 3;
will-change: transform, width;
}
#fast-bw-left {
background: linear-gradient(to right, transparent, rgba(255,23,68,0.10));
}
#fast-bw-right {
background: linear-gradient(to left, transparent, rgba(255,23,68,0.10));
}
#rds-ps-overlay {
display: none;
position: absolute;
inset: 0;
z-index: 5;
pointer-events: none;
}
.rds-ps-overlay-item {
position: absolute;
transform: translate(-50%, -50%);
pointer-events: auto;
cursor: pointer;
color: var(--text-heading);
padding: 0.34rem 0.9rem 0.28rem;
border: 1px solid color-mix(in srgb, var(--border-light) 72%, transparent);
border-radius: 6px;
background: color-mix(in srgb, var(--card-bg) 52%, transparent);
backdrop-filter: blur(14px) saturate(135%);
-webkit-backdrop-filter: blur(14px) saturate(135%);
box-shadow:
0 8px 18px color-mix(in srgb, #000000 16%, transparent),
inset 0 1px 0 color-mix(in srgb, #ffffff 10%, transparent);
text-shadow: 0 1px 10px color-mix(in srgb, var(--bg) 68%, transparent);
display: flex;
flex-direction: column;
align-items: center;
gap: 0.16rem;
text-align: center;
max-width: min(92vw, 24rem);
overflow: hidden;
text-overflow: ellipsis;
}
.rds-ps {
cursor: pointer;
}
.rds-ps-main {
display: block;
font-family: 'DSEG14 Classic', monospace;
font-size: clamp(1rem, 2.2vw, 1.45rem);
letter-spacing: 0.08em;
white-space: pre;
}
.rds-ps-gap {
color: color-mix(in srgb, currentColor 34%, var(--text-muted));
}
.rds-ps-fallback {
display: block;
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
font-size: clamp(0.72rem, 1.4vw, 0.95rem);
font-weight: 700;
letter-spacing: 0.04em;
white-space: nowrap;
}
.rds-ps-meta {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.4rem;
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
font-size: clamp(0.58rem, 1.1vw, 0.78rem);
letter-spacing: 0.04em;
color: var(--text-muted);
white-space: nowrap;
}
.rds-ps-meta-text {
display: inline-block;
}
.rds-ps-flags {
display: inline-flex;
align-items: center;
gap: 0.25rem;
}
.rds-flag {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 1.9em;
padding: 0.05rem 0.35rem;
border-radius: 999px;
border: 1px solid color-mix(in srgb, var(--border-light) 72%, transparent);
font-size: 0.92em;
font-weight: 700;
letter-spacing: 0.03em;
}
.rds-flag-active {
color: #ffd7d7;
background: color-mix(in srgb, #b31217 68%, transparent);
border-color: color-mix(in srgb, #ff7b7b 46%, transparent);
box-shadow: 0 0 10px color-mix(in srgb, #b31217 28%, transparent);
}
.rds-flag-inactive {
color: var(--text-muted);
background: color-mix(in srgb, var(--card-bg) 62%, transparent);
}
#aprs-bar-overlay,
#ais-bar-overlay,
#vdes-bar-overlay,
#ft8-bar-overlay,
#cw-bar-overlay {
display: none;
position: absolute;
top: 50%;
left: 0.45rem;
right: 0.45rem;
width: auto;
max-width: none;
transform: translateY(-50%);
z-index: 5;
pointer-events: auto;
cursor: default;
user-select: text;
color: var(--text-heading);
padding: 0.22rem 0.55rem 0.24rem;
border: 1px solid color-mix(in srgb, var(--border-light) 72%, transparent);
border-radius: 6px;
background: color-mix(in srgb, var(--card-bg) 68%, transparent);
backdrop-filter: blur(16px) saturate(130%);
-webkit-backdrop-filter: blur(16px) saturate(130%);
box-shadow:
0 10px 24px color-mix(in srgb, #000000 14%, transparent),
inset 0 1px 0 color-mix(in srgb, #ffffff 8%, transparent),
inset 0 0 0 1px color-mix(in srgb, #ffffff 4%, transparent);
max-height: min(58%, 9.5rem);
overflow-y: auto;
flex-direction: column;
gap: 0.12rem;
}
.aprs-bar-header {
position: sticky;
top: 0;
z-index: 1;
background: color-mix(in srgb, var(--card-bg) 88%, transparent);
backdrop-filter: blur(8px);
-webkit-backdrop-filter: blur(8px);
display: flex;
align-items: center;
justify-content: flex-start;
gap: 0.32rem;
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
font-size: clamp(0.6rem, 0.9vw, 0.75rem);
font-weight: 700;
letter-spacing: 0.06em;
color: var(--accent-green);
text-transform: uppercase;
padding: 0;
margin-bottom: 0.02rem;
border-bottom: 1px solid color-mix(in srgb, var(--border-light) 22%, transparent);
opacity: 0.9;
}
.aprs-bar-title {
display: inline-flex;
align-items: center;
gap: 0.1rem;
min-width: 0;
flex: 0 0 auto;
}
.aprs-bar-title-word {
display: inline-block;
}
.aprs-bar-window {
display: inline-flex;
align-items: center;
color: var(--text-muted);
font-size: 0.72em;
font-weight: 600;
letter-spacing: 0.03em;
text-transform: none;
white-space: nowrap;
}
.aprs-bar-actions {
margin-left: auto;
display: inline-flex;
align-items: center;
gap: 0.38rem;
flex: 0 0 auto;
}
.aprs-bar-clear-wrap {
display: inline-flex;
align-items: center;
flex: 0 0 auto;
padding: 0;
align-self: center;
}
.aprs-bar-clear {
display: inline;
background: transparent;
border: none;
border-radius: 0;
padding: 0;
line-height: 1;
font-family: inherit;
font-size: 0.8em;
font-weight: 600;
letter-spacing: 0.03em;
color: var(--text-muted);
cursor: pointer;
opacity: 0.82;
text-transform: uppercase;
white-space: nowrap;
transition: opacity 120ms, color 120ms;
}
.aprs-bar-clear:hover {
opacity: 1;
color: var(--accent-green);
text-decoration: underline;
}
.aprs-bar-clear-wrap:hover {
color: inherit;
}
.aprs-bar-close {
display: inline-flex;
align-items: center;
justify-content: center;
width: 1.05rem;
height: 1.05rem;
padding: 0;
border: none;
border-radius: 999px;
background: transparent;
color: var(--text-muted);
font-family: inherit;
font-size: 0.95em;
font-weight: 700;
line-height: 1;
cursor: pointer;
opacity: 0.82;
transition: opacity 120ms, color 120ms, background-color 120ms;
}
.aprs-bar-close:hover {
opacity: 1;
color: var(--accent-green);
background: color-mix(in srgb, var(--btn-bg) 70%, transparent);
}
.aprs-bar-frame {
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
font-size: clamp(0.56rem, 0.92vw, 0.7rem);
line-height: 1.12;
padding: 0.08rem 0;
border-bottom: 1px solid color-mix(in srgb, var(--border-light) 18%, transparent);
opacity: 1;
}
.aprs-bar-frame:last-child {
border-bottom: none;
}
.aprs-bar-frame-main {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
padding-right: 0.15rem;
}
.aprs-bar-pin {
display: inline-flex;
align-items: center;
justify-content: center;
background: color-mix(in srgb, var(--btn-bg) 74%, transparent);
border: 1px solid color-mix(in srgb, var(--border-light) 28%, transparent);
border-radius: 4px;
padding: 0;
margin-right: 0.28em;
width: 1.55em;
height: 1.55em;
font-size: 0.72em;
line-height: 1;
cursor: pointer;
vertical-align: middle;
opacity: 0.82;
transition: opacity 120ms, border-color 120ms, background 120ms;
}
.aprs-bar-pin:hover {
opacity: 1;
background: color-mix(in srgb, var(--btn-bg) 92%, transparent);
border-color: color-mix(in srgb, var(--accent-green) 28%, var(--border-light));
}
.aprs-bar-frame + .aprs-bar-frame {
opacity: 0.78;
}
.aprs-bar-frame + .aprs-bar-frame + .aprs-bar-frame {
opacity: 0.62;
}
.aprs-bar-frame + .aprs-bar-frame + .aprs-bar-frame + .aprs-bar-frame {
opacity: 0.46;
}
.aprs-bar-frame + .aprs-bar-frame + .aprs-bar-frame + .aprs-bar-frame + .aprs-bar-frame {
opacity: 0.34;
}
.aprs-bar-time {
color: color-mix(in srgb, var(--text-muted) 92%, transparent);
margin-right: 0.42em;
font-size: 0.94em;
}
.aprs-bar-call {
color: var(--accent-green);
font-weight: 600;
}
.aprs-bar-crc {
color: var(--accent-red);
margin-left: 0.3em;
}
.overview-toolbar {
display: flex;
align-items: center;
justify-content: flex-end;
gap: 0.75rem;
margin-bottom: 0;
position: absolute;
top: calc(var(--header-waterfall-overlap) + 0.2rem);
right: 0.15rem;
z-index: 2;
}
.overview-label {
margin-left: auto;
color: var(--text-heading);
font-size: 0.82rem;
font-weight: 700;
letter-spacing: 0.04em;
text-transform: uppercase;
}
.overview-control {
display: inline-flex;
align-items: center;
gap: 0.4rem;
color: var(--text-muted);
font-size: 0.8rem;
white-space: nowrap;
}
.overview-control .status-input {
width: auto;
min-width: 4.6rem;
padding-top: 0.22rem;
padding-bottom: 0.22rem;
font-size: 0.85rem;
}
#overview-canvas {
width: 100%;
height: var(--overview-plot-height);
display: block;
}
.header-left {
display: flex;
flex-direction: row;
align-items: center;
justify-content: flex-start;
gap: 0;
flex-shrink: 0;
}
.top-bar-actions {
display: flex;
align-items: center;
gap: 0.6rem;
min-width: 0;
}
.header-bar-btn.header-audio-btn {
width: 2rem;
height: 2rem;
min-height: 0;
padding: 2px;
display: flex;
align-items: center;
justify-content: center;
border: 1px solid var(--border-light);
border-radius: 6px;
background: var(--input-bg);
color: var(--text-muted);
cursor: pointer;
flex-shrink: 0;
}
.header-audio-btn svg {
width: 100%;
height: 100%;
}
.header-audio-btn.audio-active {
color: #00d17f;
border-color: #00d17f;
}
.header-rig-switch {
display: flex;
align-items: center;
gap: 0.35rem;
}
.header-rig-switch select {
min-width: 8rem;
height: 2rem;
padding: 0.15rem 0.35rem;
border: 1px solid var(--border-light);
border-radius: 6px;
background: var(--input-bg);
color: var(--text);
font-size: 0.85rem;
}
.header-rig-switch button {
height: 2rem;
padding: 0 0.65rem;
font-size: 0.78rem;
white-space: nowrap;
}
.header-bar-btn {
height: 2rem;
padding: 0 0.65rem;
font-size: 0.78rem;
white-space: nowrap;
}
/* Theme toggle: styled to match the active theme */
#theme-toggle {
background: #1e2a3a;
color: #e7edf9;
border-color: #3a5274;
}
[data-theme="light"] #theme-toggle {
background: #dde3ed;
color: #1a2336;
border-color: #a0aec0;
}
.header-style-pick {
display: flex;
align-items: center;
}
.header-style-pick select {
height: 2rem;
padding: 0.15rem 0.35rem;
border: 1px solid var(--border-light);
border-radius: 6px;
background: var(--input-bg);
color: var(--text);
font-size: 0.85rem;
}
.header-logo { height: 4.6em; width: auto; flex-shrink: 0; filter: drop-shadow(0 4px 12px rgba(0,0,0,0.35)); }
.subtitle { color: var(--text-muted); font-size: 0.95rem; }
.subtitle a { color: var(--accent-green); text-decoration: none; }
.subtitle a:hover { text-decoration: underline; }
.band-tag { display: inline-block; padding: 2px 6px; border-radius: 6px; background: var(--btn-bg); color: var(--text); font-size: 0.82rem; border: 1px solid var(--border-light); margin-left: 6px; }
.signal { display: flex; gap: 0.6rem; align-items: center; }
.signal-bar { flex: 1 1 auto; height: 12px; border-radius: 999px; background: var(--btn-bg); border: 1px solid var(--border-light); overflow: hidden; }
.signal-bar-fill { height: 100%; width: 0%; background: linear-gradient(90deg, var(--accent-green), var(--accent-yellow), var(--accent-red)); transition: width 150ms ease; }
.signal-value { font-size: 0.95rem; color: var(--text-heading); min-width: 48px; text-align: right; }
.meter { display: flex; gap: 0.6rem; align-items: center; }
.meter-bar { flex: 1 1 auto; height: 12px; border-radius: 999px; background: var(--btn-bg); border: 1px solid var(--border-light); overflow: hidden; }
.meter-fill { height: 100%; width: 0%; background: linear-gradient(90deg, var(--accent-green), var(--accent-yellow), var(--accent-red)); transition: width 150ms ease; }
.meter-value { font-size: 0.95rem; color: var(--text-heading); min-width: 64px; text-align: right; }
#content { display: flex; flex-direction: column; gap: 1.1rem; min-height: 0; flex: 1 1 auto; overflow: visible; position: relative; }
.tab-panel { flex: 1 1 auto; min-height: 0; overflow: visible; display: flex; flex-direction: column; }
.sub-tab-panel { flex: 1 1 auto; min-height: 0; display: flex; flex-direction: column; }
.tab-bar {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
margin-bottom: 0.85rem;
padding: 0.45rem 0 0.7rem;
border-bottom: 1px solid color-mix(in srgb, var(--border-light) 55%, transparent);
position: relative;
z-index: 2;
}
.tab-bar-left {
display: flex;
align-items: center;
gap: 1rem;
min-width: 0;
flex: 1 1 auto;
}
.tab-bar .header-main {
display: flex;
align-items: center;
gap: 0.7rem;
max-width: min(100%, 24rem);
padding: 0;
margin-left: 0;
transform: none;
flex-shrink: 0;
border-radius: 0;
background: transparent;
backdrop-filter: none;
-webkit-backdrop-filter: none;
box-shadow: none;
}
.tab-bar .header-logo {
height: 2.6rem;
}
.tab-bar .title {
font-size: 1.05rem;
line-height: 1.1;
}
.tab-bar .subtitle {
font-size: 0.78rem;
line-height: 1.15;
}
.tab-bar-nav {
display: flex;
align-items: center;
gap: 0.2rem;
min-width: 0;
flex-wrap: wrap;
}
.tab {
background: transparent;
border: none;
border-bottom: 2px solid transparent;
border-radius: 0;
padding: 0.5rem 0.95rem;
color: var(--text-muted);
cursor: pointer;
font-size: 0.95rem;
height: auto;
}
.tab.active { border-bottom-color: var(--accent-green); color: var(--accent-green); font-weight: 600; }
.tab:hover:not(.active) { color: var(--text); }
/* Tab icons — hidden on desktop, shown on mobile bottom nav */
.tab-icon {
display: none;
width: 20px;
height: 20px;
flex-shrink: 0;
}
.tab-label { display: block; }
.about-table { width: 100%; border-collapse: collapse; }
.about-table td { padding: 0.5rem 0.6rem; border-bottom: 1px solid var(--border); }
.about-table tr:last-child td { border-bottom: none; }
.about-table td:first-child { color: var(--text-muted); width: 40%; }
.plugin-item { padding: 0.5rem 0.6rem; border-bottom: 1px solid var(--border); color: var(--text); }
.plugin-item:last-child { border-bottom: none; }
.footer { display: flex; justify-content: space-between; align-items: baseline; margin-top: auto; padding-top: 1rem; flex-shrink: 0; }
.full-row { grid-column: 1 / -1; }
.copyright { color: var(--text-muted); font-size: 0.75rem; opacity: 0.7; }
.copyright a { color: var(--accent-green); text-decoration: none; }
.copyright a:hover { text-decoration: underline; }
.gh-link-wrap {
display: inline-flex;
vertical-align: middle;
margin: 0 0.15rem;
}
.gh-link {
display: inline-flex;
align-items: center;
gap: 0.34rem;
padding: 0.18rem 0.5rem;
border-radius: 999px;
border: 1px solid color-mix(in srgb, var(--border-light) 72%, transparent);
background: color-mix(in srgb, var(--btn-bg) 78%, transparent);
color: var(--text-heading);
line-height: 1;
box-shadow: inset 0 1px 0 color-mix(in srgb, #ffffff 8%, transparent);
}
.gh-link:hover {
text-decoration: none;
border-color: color-mix(in srgb, var(--accent-green) 48%, var(--border-light));
background: color-mix(in srgb, var(--btn-bg) 90%, transparent);
}
.gh-link-icon {
width: 0.95rem;
height: 0.95rem;
flex-shrink: 0;
fill: currentColor;
}
.vol-label {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.15rem;
color: var(--text-muted);
font-size: 0.82rem;
white-space: nowrap;
}
.vol-pct {
font-size: 0.72rem;
color: var(--text-muted);
line-height: 1;
}
.vol-slider {
-webkit-appearance: none;
appearance: none;
width: 80px;
height: 6px;
border-radius: 3px;
background: var(--btn-bg);
border: 1px solid var(--border-light);
outline: none;
cursor: pointer;
}
.vol-slider::-webkit-slider-thumb {
-webkit-appearance: none;
appearance: none;
width: 14px;
height: 14px;
border-radius: 50%;
background: var(--accent-green);
border: none;
cursor: pointer;
}
.vol-slider::-moz-range-thumb {
width: 14px;
height: 14px;
border-radius: 50%;
background: var(--accent-green);
border: none;
cursor: pointer;
}
#audio-level {
flex: 1 1 auto;
height: 12px;
border-radius: 999px;
background: var(--audio-level-bg);
border: 1px solid var(--audio-level-border);
overflow: hidden;
min-width: 80px;
}
#audio-level-fill {
height: 100%;
width: 0%;
background: linear-gradient(90deg, var(--audio-level-fill-start), var(--audio-level-fill-end));
transition: width 100ms ease;
}
.sub-tab-bar { display: flex; border-bottom: 1px solid var(--border); margin-bottom: 0.75rem; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.sub-tab { flex-shrink: 0; background: transparent; border: none; border-bottom: 2px solid transparent; border-radius: 0; padding: 0.35rem 0.75rem; color: var(--text-muted); cursor: pointer; font-size: 0.85rem; height: auto; }
.sub-tab.active { border-bottom-color: var(--accent-green); color: var(--accent-green); font-weight: 600; }
.sub-tab:hover:not(.active) { color: var(--text); }
.decode-history-overlay {
position: fixed;
inset: 0;
z-index: 9500;
display: flex;
align-items: center;
justify-content: center;
padding: 1.2rem;
background: color-mix(in srgb, var(--bg) 36%, transparent);
backdrop-filter: blur(6px);
-webkit-backdrop-filter: blur(6px);
pointer-events: none;
opacity: 1;
visibility: visible;
transition: opacity 140ms ease, visibility 140ms ease;
}
.decode-history-overlay.is-hidden {
opacity: 0;
visibility: hidden;
}
.decode-history-overlay.content-overlay {
position: absolute;
border-radius: 0 0 0.9rem 0.9rem;
}
.decode-history-overlay.content-overlay.conn-lost-fullscreen {
position: fixed;
border-radius: 0;
}
.decode-history-overlay-card {
min-width: min(26rem, calc(100vw - 2.4rem));
max-width: min(30rem, calc(100vw - 2.4rem));
padding: 0.9rem 1rem;
border-radius: 0.9rem;
border: 1px solid color-mix(in srgb, var(--border-light) 72%, transparent);
background: color-mix(in srgb, var(--card-bg) 88%, transparent);
box-shadow: 0 18px 40px rgba(0, 0, 0, 0.22);
text-align: center;
}
.decode-history-overlay-title {
font-size: 0.98rem;
font-weight: 800;
color: var(--text-heading);
}
.decode-history-overlay-sub {
margin-top: 0.24rem;
font-size: 0.82rem;
color: var(--text-muted);
}
#tab-map {
display: flex;
flex-direction: column;
min-height: 0;
gap: 0.85rem;
}
#map-stage {
position: relative;
flex: 0 1 auto;
min-height: 0;
overflow: hidden;
border-radius: 6px;
border: 1px solid color-mix(in srgb, var(--border-light) 78%, transparent);
background:
linear-gradient(180deg, color-mix(in srgb, var(--card-bg) 86%, transparent), color-mix(in srgb, var(--card-bg) 64%, transparent)),
color-mix(in srgb, var(--input-bg) 88%, transparent);
}
#aprs-map {
width: 100%;
min-height: 0;
border-radius: 0;
}
.map-qso-summary {
display: flex;
flex-direction: column;
gap: 0.75rem;
padding: 0.9rem 1rem 1rem;
border-radius: 0.8rem;
border: 1px solid color-mix(in srgb, var(--border-light) 76%, transparent);
background:
linear-gradient(180deg, color-mix(in srgb, var(--card-bg) 90%, transparent), color-mix(in srgb, var(--input-bg) 82%, transparent));
box-shadow: inset 0 1px 0 color-mix(in srgb, white 5%, transparent);
}
.map-qso-summary-head {
display: flex;
align-items: baseline;
justify-content: space-between;
gap: 0.75rem;
}
.map-qso-summary-title {
font-size: 0.88rem;
font-weight: 800;
letter-spacing: 0.08em;
text-transform: uppercase;
color: var(--text-heading);
}
.map-qso-summary-subtitle {
margin-top: 0.18rem;
font-size: 0.78rem;
color: var(--text-muted);
}
.map-qso-summary-list {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
gap: 0.65rem;
}
.map-qso-summary-empty {
padding: 0.85rem 0.9rem;
border-radius: 0.75rem;
border: 1px dashed color-mix(in srgb, var(--border-light) 76%, transparent);
background: color-mix(in srgb, var(--input-bg) 84%, transparent);
color: var(--text-muted);
font-size: 0.82rem;
}
button.map-qso-card {
display: flex;
appearance: none;
-webkit-appearance: none;
width: 100%;
flex-direction: column;
align-items: stretch;
gap: 0.5rem;
min-width: 0;
margin: 0;
padding: 0.8rem 0.85rem;
box-sizing: border-box;
min-height: 0;
height: auto;
border-radius: 0.75rem;
border: 1px solid color-mix(in srgb, var(--border-light) 74%, transparent);
background: color-mix(in srgb, var(--card-bg) 78%, transparent);
font: inherit;
color: inherit;
line-height: inherit;
text-align: left;
cursor: pointer;
box-shadow: none;
transition: border-color 120ms ease, background 120ms ease, transform 120ms ease, box-shadow 120ms ease;
}
button.map-qso-card:hover:not(:disabled) {
border-color: color-mix(in srgb, var(--accent-green) 38%, var(--border-light));
background: color-mix(in srgb, var(--card-bg) 70%, transparent);
box-shadow: none;
}
button.map-qso-card.is-selected {
border-color: color-mix(in srgb, var(--accent-green) 62%, var(--border-light));
background: color-mix(in srgb, var(--accent-green) 10%, var(--card-bg));
box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent-green) 18%, transparent);
}
button.map-qso-card:active:not(:disabled) {
transform: translateY(1px);
background: color-mix(in srgb, var(--card-bg) 66%, transparent);
border-color: color-mix(in srgb, var(--accent-green) 46%, var(--border-light));
box-shadow: none;
}
button.map-qso-card:focus-visible {
outline: 2px solid color-mix(in srgb, var(--accent-green) 52%, transparent);
outline-offset: 2px;
}
.map-qso-card-head {
display: flex;
align-items: flex-start;
justify-content: space-between;
gap: 0.75rem;
}
.map-qso-card-rank {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 1.6rem;
min-height: 1.6rem;
padding: 0 0.4rem;
border-radius: 999px;
background: color-mix(in srgb, var(--accent-green) 16%, transparent);
color: var(--accent-green);
font-size: 0.76rem;
font-weight: 800;
}
.map-qso-card-distance {
flex: 0 0 auto;
font-size: 0.95rem;
font-weight: 800;
color: var(--text-heading);
white-space: nowrap;
}
.map-qso-card-body {
display: flex;
flex-direction: column;
gap: 0.24rem;
min-width: 0;
}
.map-qso-card-pair {
font-size: 0.92rem;
font-weight: 700;
color: var(--text);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.map-qso-card-meta {
display: flex;
flex-wrap: wrap;
gap: 0.35rem 0.45rem;
align-items: center;
}
.map-qso-card-pill {
display: inline-flex;
align-items: center;
min-height: 1.35rem;
padding: 0.04rem 0.42rem;
border-radius: 999px;
border: 1px solid color-mix(in srgb, var(--border-light) 74%, transparent);
background: color-mix(in srgb, var(--input-bg) 86%, transparent);
color: var(--text-muted);
font-size: 0.7rem;
font-weight: 700;
letter-spacing: 0.04em;
text-transform: uppercase;
}
.map-qso-card-grids {
color: var(--text-muted);
font-size: 0.78rem;
}
.map-qso-card-band {
color: var(--text);
border-color: color-mix(in srgb, var(--band-color, var(--accent-green)) 40%, transparent);
background: color-mix(in srgb, var(--band-color, var(--accent-green)) 14%, transparent);
}
.map-overlay-panel {
position: absolute;
right: 0.7rem;
bottom: 0.7rem;
z-index: 410;
display: flex;
flex-direction: column;
gap: 0.45rem;
width: min(30rem, calc(100% - 4.9rem));
max-height: calc(100% - 1.4rem);
padding: 0.7rem 0.75rem;
border-radius: 0.8rem;
border: 1px solid color-mix(in srgb, var(--border-light) 74%, transparent);
background: color-mix(in srgb, var(--card-bg) 82%, transparent);
box-shadow: 0 16px 30px rgba(0, 0, 0, 0.24);
backdrop-filter: blur(14px);
-webkit-backdrop-filter: blur(14px);
overflow: auto;
transition: opacity 140ms ease, transform 140ms ease, visibility 140ms ease;
}
.map-overlay-panel.is-hidden {
opacity: 0;
visibility: hidden;
transform: translateY(0.25rem);
pointer-events: none;
}
.map-corner-controls {
position: absolute;
top: 0.7rem;
right: 0.7rem;
z-index: 410;
display: flex;
flex-direction: column;
align-items: flex-end;
gap: 0.4rem;
}
.map-fullscreen-btn {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 1.9rem;
padding: 0.18rem 0.65rem;
border-radius: 6px;
border: 1px solid color-mix(in srgb, var(--border-light) 74%, transparent);
background: color-mix(in srgb, var(--card-bg) 82%, transparent);
color: var(--text);
font-size: 0.76rem;
font-weight: 700;
letter-spacing: 0.02em;
cursor: pointer;
backdrop-filter: blur(8px);
-webkit-backdrop-filter: blur(8px);
}
.map-fullscreen-btn:hover {
border-color: color-mix(in srgb, var(--accent-green) 34%, var(--border-light));
color: var(--text-heading);
}
.map-overlay-toggle-btn {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 1.9rem;
padding: 0.18rem 0.65rem;
border-radius: 6px;
border: 1px solid color-mix(in srgb, var(--border-light) 74%, transparent);
background: color-mix(in srgb, var(--card-bg) 82%, transparent);
color: var(--text);
font-size: 0.76rem;
font-weight: 700;
letter-spacing: 0.02em;
cursor: pointer;
backdrop-filter: blur(8px);
-webkit-backdrop-filter: blur(8px);
}
.map-overlay-toggle-btn:hover {
border-color: color-mix(in srgb, var(--accent-green) 34%, var(--border-light));
color: var(--text-heading);
}
.map-band-legend {
position: absolute;
left: 0.7rem;
bottom: 0.7rem;
z-index: 410;
display: flex;
flex-direction: column;
gap: 0.45rem;
width: min(14rem, calc(100% - 5.8rem));
max-height: min(40%, 18rem);
padding: 0.65rem 0.7rem;
border-radius: 0.8rem;
border: 1px solid color-mix(in srgb, var(--border-light) 74%, transparent);
background: color-mix(in srgb, var(--card-bg) 78%, transparent);
box-shadow: 0 16px 30px rgba(0, 0, 0, 0.2);
backdrop-filter: blur(14px);
-webkit-backdrop-filter: blur(14px);
overflow: auto;
}
.map-band-legend.is-empty {
display: none;
}
.map-band-legend-title {
font-size: 0.72rem;
font-weight: 800;
letter-spacing: 0.1em;
text-transform: uppercase;
color: var(--text-muted);
}
.map-band-legend-list {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(5.4rem, 1fr));
gap: 0.35rem 0.55rem;
}
.map-band-legend-item {
display: inline-flex;
align-items: center;
gap: 0.4rem;
min-width: 0;
}
.map-band-legend-swatch {
flex: 0 0 auto;
width: 0.78rem;
height: 0.78rem;
border-radius: 999px;
background: var(--legend-color, var(--accent-green));
box-shadow: 0 0 0 1px color-mix(in srgb, var(--legend-color, var(--accent-green)) 44%, rgba(255, 255, 255, 0.18));
}
.map-band-legend-text {
min-width: 0;
font-size: 0.76rem;
font-weight: 700;
color: var(--text);
white-space: nowrap;
}
#map-stage:fullscreen,
#map-stage:-webkit-full-screen,
#map-stage.map-fake-fullscreen {
background: var(--bg);
width: 100%;
height: 100%;
padding: 0;
box-sizing: border-box;
}
/* CSS-based fake fullscreen for browsers that block the Fullscreen API
(notably mobile Safari, which only allows fullscreen for <video>). */
#map-stage.map-fake-fullscreen {
position: fixed;
inset: 0;
z-index: 9000;
height: 100dvh;
}
body.map-fake-fullscreen-active {
overflow: hidden;
touch-action: none;
}
#map-stage:fullscreen #aprs-map,
#map-stage:-webkit-full-screen #aprs-map,
#map-stage.map-fake-fullscreen #aprs-map {
border-radius: 0;
height: 100% !important;
}
.aprs-controls { display: flex; gap: 0.6rem; align-items: center; margin-bottom: 0.75rem; }
.aprs-controls > button.active,
.ft8-controls > button.active,
.cw-controls > button.active {
border-color: color-mix(in srgb, var(--accent-green) 58%, var(--border-light));
color: var(--accent-green);
background: color-mix(in srgb, var(--accent-green) 10%, var(--btn-bg));
}
.aprs-summary {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 0.6rem;
margin-bottom: 0.75rem;
}
.aprs-summary-card {
display: flex;
flex-direction: column;
gap: 0.18rem;
padding: 0.45rem 0.55rem;
border: 1px solid var(--border-light);
border-radius: 6px;
background: color-mix(in srgb, var(--card-bg) 84%, transparent);
}
.aprs-summary-label {
color: var(--text-muted);
font-size: 0.72rem;
font-weight: 700;
letter-spacing: 0.06em;
text-transform: uppercase;
}
.aprs-summary-value {
color: var(--text);
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
font-size: 0.8rem;
line-height: 1.3;
}
.aprs-filter-row {
display: flex;
flex-wrap: wrap;
gap: 0.45rem;
margin-bottom: 0.6rem;
}
.aprs-chip {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 1.65rem;
padding: 0.08rem 0.5rem;
border-radius: 0.4rem;
border: 1px solid var(--filter-border);
background: var(--filter-bg);
color: var(--filter-fg);
font-size: 0.68rem;
font-weight: 700;
letter-spacing: 0.03em;
cursor: pointer;
}
.aprs-chip.active {
color: var(--card-bg);
background: var(--accent-green);
border-color: var(--accent-green);
}
.aprs-chip:hover:not(.active) {
border-color: var(--accent-green);
color: var(--text);
}
.ais-summary {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 0.6rem;
margin-bottom: 0.75rem;
}
.ais-summary-card {
display: flex;
flex-direction: column;
gap: 0.18rem;
padding: 0.45rem 0.55rem;
border: 1px solid var(--border-light);
border-radius: 6px;
background: color-mix(in srgb, var(--card-bg) 84%, transparent);
}
.ais-summary-label {
color: var(--text-muted);
font-size: 0.72rem;
font-weight: 700;
letter-spacing: 0.06em;
text-transform: uppercase;
}
.ais-summary-value {
color: var(--text);
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
font-size: 0.8rem;
line-height: 1.3;
}
#subtab-ais {
display: flex;
flex-direction: column;
}
#subtab-vdes {
display: flex;
flex-direction: column;
}
#subtab-aprs {
display: flex;
flex-direction: column;
}
#aprs-packets,
#ais-messages,
#vdes-messages { max-height: 360px; overflow-y: auto; border: 1px solid var(--border-light); border-radius: 6px; background: var(--input-bg); font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; }
#aprs-packets {
flex: 0 1 auto;
height: calc(100vh - 28rem);
min-height: 16rem;
max-height: calc(100vh - 28rem);
}
#ais-messages {
flex: 0 1 auto;
height: calc(100vh - 24rem);
min-height: 16rem;
max-height: calc(100vh - 24rem);
}
#vdes-messages {
flex: 0 1 auto;
height: calc(100vh - 24rem);
min-height: 16rem;
max-height: calc(100vh - 24rem);
}
.aprs-packet { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 0.82rem; padding: 0.45rem 0.55rem; border-bottom: 1px solid var(--border); line-height: 1.35; }
.aprs-packet:last-child { border-bottom: none; }
.aprs-packet-new {
animation: aprs-row-flash 1.2s ease;
}
.aprs-packet-crc {
opacity: 0.6;
}
.aprs-row-head,
.aprs-row-meta,
.aprs-row-detail,
.aprs-row-actions {
display: flex;
align-items: center;
gap: 0.45rem;
flex-wrap: wrap;
}
.aprs-row-head + .aprs-row-meta,
.aprs-row-meta + .aprs-row-detail,
.aprs-row-detail + .aprs-row-actions {
margin-top: 0.2rem;
}
.aprs-row-detail {
color: var(--text-muted);
font-size: 0.78rem;
}
.aprs-row-actions {
margin-top: 0.28rem;
}
.aprs-badge {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 1.2rem;
padding: 0.02rem 0.38rem;
border-radius: 999px;
border: 1px solid color-mix(in srgb, var(--border-light) 78%, transparent);
background: color-mix(in srgb, var(--card-bg) 72%, transparent);
color: var(--text-muted);
font-size: 0.68rem;
font-weight: 700;
letter-spacing: 0.05em;
text-transform: uppercase;
}
.aprs-badge-type {
color: var(--text);
}
.aprs-badge-type-position {
color: #77d6a5;
border-color: color-mix(in srgb, #77d6a5 42%, transparent);
background: color-mix(in srgb, #77d6a5 12%, transparent);
}
.aprs-badge-type-message {
color: #8ec8ff;
border-color: color-mix(in srgb, #8ec8ff 42%, transparent);
background: color-mix(in srgb, #8ec8ff 12%, transparent);
}
.aprs-badge-type-weather {
color: #ffd77a;
border-color: color-mix(in srgb, #ffd77a 42%, transparent);
background: color-mix(in srgb, #ffd77a 14%, transparent);
}
.aprs-badge-type-telemetry {
color: #d4a5ff;
border-color: color-mix(in srgb, #d4a5ff 42%, transparent);
background: color-mix(in srgb, #d4a5ff 12%, transparent);
}
.aprs-badge-crc {
color: #ff9a9a;
border-color: color-mix(in srgb, #ff9a9a 42%, transparent);
background: color-mix(in srgb, #ff9a9a 10%, transparent);
}
.aprs-meta-text {
color: var(--text-muted);
font-size: 0.76rem;
}
.aprs-inline-btn {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 1.7rem;
padding: 0.08rem 0.42rem;
border-radius: 999px;
border: 1px solid var(--filter-border);
background: var(--filter-bg);
color: var(--filter-fg);
font: inherit;
font-size: 0.74rem;
cursor: pointer;
}
.aprs-inline-btn:hover {
border-color: var(--accent-green);
color: var(--text);
}
.aprs-details {
width: 100%;
}
.aprs-details summary {
cursor: pointer;
color: var(--accent-green);
font-size: 0.76rem;
user-select: none;
}
.aprs-details[open] summary {
margin-bottom: 0.35rem;
}
.aprs-details-grid {
display: grid;
grid-template-columns: auto 1fr;
gap: 0.2rem 0.65rem;
font-size: 0.75rem;
color: var(--text-muted);
}
.aprs-detail-label {
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.05em;
}
.aprs-detail-value {
color: var(--text);
word-break: break-word;
}
.ais-message { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 0.82rem; padding: 0.45rem 0.55rem; border-bottom: 1px solid var(--border); line-height: 1.35; }
.ais-message:last-child { border-bottom: none; }
.vdes-message { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 0.82rem; padding: 0.45rem 0.55rem; border-bottom: 1px solid var(--border); line-height: 1.35; }
.vdes-message:last-child { border-bottom: none; }
.aprs-call { color: var(--accent-green); font-weight: 600; }
.ais-call { color: var(--accent-red); font-weight: 600; }
.vdes-call { color: #8ec8ff; font-weight: 600; }
.aprs-time { color: var(--text-muted); margin-right: 0.5rem; }
.ais-time { color: var(--text-muted); margin-right: 0.5rem; }
.vdes-time { color: var(--text-muted); margin-right: 0.5rem; }
.ais-row-head,
.ais-row-meta,
.ais-row-detail {
display: flex;
align-items: center;
gap: 0.45rem;
flex-wrap: wrap;
}
.ais-row-head + .ais-row-meta,
.ais-row-meta + .ais-row-detail {
margin-top: 0.2rem;
}
.ais-row-detail {
color: var(--text-muted);
font-size: 0.78rem;
}
.ais-badge {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 1.2rem;
padding: 0.02rem 0.38rem;
border-radius: 999px;
border: 1px solid color-mix(in srgb, var(--border-light) 78%, transparent);
background: color-mix(in srgb, var(--card-bg) 72%, transparent);
color: var(--text-muted);
font-size: 0.68rem;
font-weight: 700;
letter-spacing: 0.05em;
text-transform: uppercase;
}
.ais-badge-channel-a {
color: #77d6a5;
border-color: color-mix(in srgb, #77d6a5 42%, transparent);
background: color-mix(in srgb, #77d6a5 12%, transparent);
}
.ais-badge-channel-b {
color: #ff9a7a;
border-color: color-mix(in srgb, #ff9a7a 42%, transparent);
background: color-mix(in srgb, #ff9a7a 14%, transparent);
}
.ais-badge-type {
color: var(--text);
}
.ais-meta-text {
color: var(--text-muted);
font-size: 0.76rem;
}
.ais-pos-link {
color: var(--accent-red);
text-decoration: none;
}
.ais-pos-link:hover {
text-decoration: underline;
}
.vdes-row-head,
.vdes-row-meta,
.vdes-row-detail {
display: flex;
align-items: center;
gap: 0.45rem;
flex-wrap: wrap;
}
.vdes-row-head + .vdes-row-meta,
.vdes-row-meta + .vdes-row-detail {
margin-top: 0.2rem;
}
.vdes-row-detail {
color: var(--text-muted);
font-size: 0.78rem;
}
.vdes-badge {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 1.2rem;
padding: 0.02rem 0.38rem;
border-radius: 999px;
border: 1px solid color-mix(in srgb, #8ec8ff 42%, transparent);
background: color-mix(in srgb, #8ec8ff 12%, transparent);
color: #8ec8ff;
font-size: 0.68rem;
font-weight: 700;
letter-spacing: 0.05em;
text-transform: uppercase;
}
.vdes-raw {
color: var(--text-muted);
font-size: 0.76rem;
word-break: break-all;
}
.aprs-symbol { display: inline-block; width: 24px; height: 24px; background-size: 384px 192px; vertical-align: middle; margin-right: 0.3rem; }
.aprs-pos { color: var(--accent-green); text-decoration: none; margin-left: 0.3rem; font-size: 0.8rem; }
.aprs-pos:hover { text-decoration: underline; }
.leaflet-popup-content-wrapper, .leaflet-popup-tip { background: color-mix(in srgb, var(--card-bg) 84%, transparent) !important; color: var(--text) !important; box-shadow: 0 3px 14px rgba(0,0,0,0.45) !important; }
.leaflet-popup-close-button { color: var(--text-muted) !important; }
.leaflet-popup-close-button:hover { color: var(--text) !important; }
.aprs-popup { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 0.82rem; min-width: 12rem; max-width: 22rem; }
.aprs-popup-call { font-weight: 700; font-size: 1em; color: var(--accent-green); margin-bottom: 0.18rem; }
.aprs-popup-meta { font-size: 0.85em; color: var(--text-muted); margin-bottom: 0.3rem; }
.aprs-popup-table { border-collapse: collapse; width: 100%; margin-bottom: 0.3rem; }
.aprs-popup-table td { padding: 0.06rem 0.3rem 0.06rem 0; vertical-align: top; font-size: 0.88em; }
.aprs-popup-label { color: var(--text-muted); white-space: nowrap; padding-right: 0.5rem !important; }
.aprs-popup-info { font-size: 0.85em; color: var(--text); border-top: 1px solid var(--border-light); padding-top: 0.25rem; margin-top: 0.1rem; word-break: break-word; }
.decode-locator-tip {
min-width: 16rem;
max-width: 26rem;
max-height: min(22rem, 60vh);
overflow: auto;
padding: 0.1rem 0.05rem 0.05rem;
color: var(--text);
}
.decode-locator-tip-title {
color: var(--accent-yellow);
font-weight: 700;
font-size: 0.9rem;
letter-spacing: 0.03em;
}
.decode-locator-tip-subtitle {
margin-top: 0.1rem;
margin-bottom: 0.45rem;
font-size: 0.75rem;
color: var(--text-muted);
}
.decode-locator-tip-row + .decode-locator-tip-row {
margin-top: 0.45rem;
padding-top: 0.4rem;
border-top: 1px solid color-mix(in srgb, var(--border-light) 70%, transparent);
}
.decode-locator-tip-head {
display: flex;
align-items: baseline;
justify-content: space-between;
gap: 0.75rem;
}
.decode-locator-tip-name {
font-weight: 600;
color: var(--text-heading);
}
.decode-locator-tip-time {
flex: 0 0 auto;
font-size: 0.75rem;
color: var(--text-muted);
white-space: nowrap;
}
.decode-locator-tip-meta {
margin-top: 0.12rem;
font-size: 0.74rem;
color: var(--text-muted);
}
.decode-locator-tip-note {
margin-top: 0.2rem;
font-size: 0.76rem;
line-height: 1.3;
color: var(--text);
word-break: break-word;
}
.aprs-radio-path { stroke-dasharray: 10 5 !important; animation: aprs-radio-path-flow 0.7s linear infinite; }
.locator-radio-path { stroke-dasharray: 12 6 !important; animation: aprs-radio-path-flow 0.7s linear infinite; }
.decode-contact-path {
stroke-dasharray: 9 6 !important;
filter: drop-shadow(0 0 3px color-mix(in srgb, currentColor 34%, transparent));
animation: aprs-radio-path-flow 0.85s linear infinite;
}
.decode-contact-distance-label {
background: transparent;
border: none;
}
.decode-contact-distance-pill {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 4.25rem;
padding: 0.16rem 0.5rem;
border-radius: 999px;
border: 1px solid color-mix(in srgb, var(--accent-green) 40%, var(--border-light));
background: color-mix(in srgb, var(--card-bg) 88%, transparent);
color: color-mix(in srgb, var(--accent-green) 72%, var(--accent-yellow));
box-shadow: 0 8px 18px rgba(0, 0, 0, 0.22);
font-size: 0.72rem;
font-weight: 700;
letter-spacing: 0.03em;
white-space: nowrap;
pointer-events: none;
}
.trx-locator-selected { stroke-opacity: 1 !important; stroke-width: 3.25px !important; filter: drop-shadow(0 0 6px color-mix(in srgb, var(--accent-green) 52%, transparent)); animation: trx-locator-breathe 1.6s ease-in-out infinite; }
.trx-receiver-marker { stroke: var(--accent-green) !important; fill: var(--accent-green) !important; }
.receiver-popup-active { font-size: 0.75em; background: rgba(194,75,26,0.15); color: var(--accent-green); border: 1px solid rgba(194,75,26,0.3); border-radius: 3px; padding: 0 0.25rem; margin-left: 0.3rem; vertical-align: middle; }
@keyframes aprs-radio-path-flow { to { stroke-dashoffset: -15; } }
.map-paths-static .decode-contact-path,
.map-paths-static .aprs-radio-path,
.map-paths-static .locator-radio-path {
animation: none;
filter: none;
}
@keyframes trx-locator-breathe {
0%, 100% { stroke-width: 2.4px; stroke-opacity: 0.78; filter: drop-shadow(0 0 2px color-mix(in srgb, var(--accent-green) 18%, transparent)); }
50% { stroke-width: 4.2px; stroke-opacity: 1; filter: drop-shadow(0 0 10px color-mix(in srgb, var(--accent-green) 52%, transparent)); }
}
.aprs-bar-pos { background: none; border: none; padding: 0; margin-left: 0.4em; font-family: inherit; font-size: inherit; color: var(--accent-green); cursor: pointer; }
.aprs-bar-pos:hover { text-decoration: underline; }
.aprs-byte { color: var(--accent-yellow); background: rgba(255, 214, 0, 0.12); border: 1px solid rgba(255, 214, 0, 0.25); border-radius: 4px; padding: 0 0.2rem; margin: 0 0.1rem; font-size: 0.78em; }
@keyframes aprs-row-flash {
0% { background: color-mix(in srgb, var(--accent-green) 14%, transparent); }
100% { background: transparent; }
}
.ft8-controls { display: flex; gap: 0.6rem; align-items: center; margin-bottom: 0.75rem; }
.ft8-filter {
flex: 1;
min-width: 10rem;
height: var(--control-height);
box-sizing: border-box;
background: var(--filter-bg);
color: var(--filter-fg);
border: 1px solid var(--filter-border);
border-radius: 6px;
padding: 0.45rem 0.55rem;
}
.ft8-filter::placeholder { color: color-mix(in srgb, var(--filter-fg) 55%, transparent); }
.ft8-header { display: flex; gap: 0.6rem; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-muted); border-bottom: 1px solid var(--border); padding: 0 0 0.35rem 0; margin-bottom: 0.35rem; }
#ft8-messages,
#ft4-messages,
#ft2-messages,
#wspr-messages { flex: 1 1 0; min-height: 120px; overflow-y: auto; border: 1px solid var(--border-light); border-radius: 6px; background: var(--input-bg); font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 0.85rem; padding: 0.35rem 0.5rem; }
.ft8-row { display: flex; gap: 0.6rem; line-height: 1.4; border-bottom: 1px solid var(--border); padding: 0.25rem 0; }
.ft8-row:last-child { border-bottom: none; }
.ft8-time { color: var(--text-muted); min-width: 4.6rem; }
.ft8-snr { color: var(--accent-yellow); min-width: 3.6rem; text-align: right; }
.ft8-dt { color: var(--text-muted); min-width: 3.6rem; text-align: right; }
.ft8-freq { color: var(--accent-green); min-width: 4.6rem; text-align: right; }
.ft8-msg { flex: 1; }
.ft8-locator { color: var(--accent-green); background: rgba(0, 209, 127, 0.12); border: 1px solid rgba(0, 209, 127, 0.25); border-radius: 4px; padding: 0 0.2rem; margin: 0 0.1rem; font-weight: 600; }
.ft8-locator[data-locator-grid] { cursor: pointer; user-select: none; }
.ft8-locator[data-locator-grid]:hover { filter: brightness(1.12); }
.ft8-locator[data-locator-grid]:focus-visible { outline: 2px solid color-mix(in srgb, var(--accent-green) 66%, transparent); outline-offset: 1px; }
.map-locator-filters {
display: flex;
flex-direction: column;
gap: 0.3rem;
margin-bottom: 0.55rem;
}
.map-locator-filter-group {
display: flex;
align-items: flex-start;
gap: 0.5rem;
flex-wrap: wrap;
}
.map-locator-filter-label {
flex: 0 0 auto;
min-width: 4.4rem;
padding-top: 0.35rem;
font-size: 0.72rem;
font-weight: 700;
letter-spacing: 0.03em;
text-transform: uppercase;
color: var(--text-muted);
}
.map-locator-chip-row {
display: flex;
flex: 1 1 auto;
flex-wrap: wrap;
gap: 0.45rem;
}
.map-locator-phase-row {
display: flex;
flex: 1 1 auto;
flex-wrap: wrap;
gap: 0.45rem;
}
.map-locator-phase-btn {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 1.8rem;
padding: 0.1rem 0.65rem;
border-radius: 6px;
border: 1px solid color-mix(in srgb, var(--border-light) 82%, transparent);
background: color-mix(in srgb, var(--input-bg) 92%, transparent);
color: var(--text-muted);
font-size: 0.76rem;
font-weight: 700;
letter-spacing: 0.02em;
text-transform: uppercase;
cursor: pointer;
transition: border-color 120ms ease, background 120ms ease, color 120ms ease;
}
.map-locator-phase-btn:hover {
border-color: color-mix(in srgb, var(--accent-green) 24%, var(--border-light));
color: var(--text);
}
.map-locator-phase-btn.is-active {
border-color: var(--accent-green);
background: color-mix(in srgb, var(--accent-green) 10%, var(--input-bg));
color: var(--accent-green);
}
.map-locator-empty {
font-size: 0.74rem;
color: var(--text-muted);
opacity: 0.8;
align-self: flex-start;
padding-top: 0.2rem;
}
.map-locator-chip {
--chip-color: var(--filter-border);
display: inline-flex;
align-items: center;
gap: 0.35rem;
min-height: 1.8rem;
padding: 0.1rem 0.55rem;
border-radius: 6px;
border: 1px solid color-mix(in srgb, var(--chip-color) 52%, var(--border-light));
background: color-mix(in srgb, var(--chip-color) 8%, var(--input-bg));
color: var(--text);
cursor: pointer;
transition: border-color 120ms ease, background 120ms ease, opacity 120ms ease, color 120ms ease;
}
.map-locator-chip:hover {
color: var(--text-heading);
}
.map-locator-chip.is-default {
border-color: color-mix(in srgb, var(--border-light) 74%, transparent);
background: color-mix(in srgb, var(--input-bg) 94%, transparent);
color: var(--text-muted);
}
.map-locator-chip.is-inactive {
opacity: 0.62;
border-color: color-mix(in srgb, var(--border-light) 68%, transparent);
background: color-mix(in srgb, var(--input-bg) 96%, transparent);
}
.map-locator-chip-text {
font-size: 0.77rem;
font-weight: 600;
}
.map-search-input {
flex: 1 1 15rem;
width: 100%;
max-width: none;
min-height: 1.95rem;
padding: 0.3rem 0.55rem;
border-radius: 7px;
border: 1px solid color-mix(in srgb, var(--border-light) 76%, transparent);
background: color-mix(in srgb, var(--card-bg) 72%, transparent);
color: var(--text);
font-size: 0.82rem;
}
.map-search-input::placeholder {
color: color-mix(in srgb, var(--text-muted) 92%, transparent);
}
.map-history-select {
flex: 1 1 10rem;
width: 100%;
max-width: 12rem;
min-height: 1.95rem;
padding: 0.3rem 0.55rem;
border-radius: 7px;
border: 1px solid color-mix(in srgb, var(--border-light) 76%, transparent);
background: color-mix(in srgb, var(--card-bg) 72%, transparent);
color: var(--text);
font-size: 0.82rem;
}
.rds-grid { display: grid; grid-template-columns: auto 1fr; gap: 0.4rem 1rem; align-items: baseline; margin-bottom: 1rem; }
.rds-field { display: contents; }
.rds-label { color: var(--text-muted); font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap; }
.rds-value { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 0.95rem; color: var(--text); }
.rds-ps { font-size: 1.1rem; font-weight: 600; letter-spacing: 0.08em; color: var(--accent-green); }
.rds-text { white-space: normal; overflow-wrap: anywhere; line-height: 1.35; }
.rds-af-list { display: flex; flex-wrap: wrap; gap: 0.35rem; align-items: center; }
.rds-af-btn {
height: 1.7rem;
padding: 0 0.55rem;
border: 1px solid var(--border-light);
border-radius: 999px;
background: var(--input-bg);
color: var(--text);
font: inherit;
cursor: pointer;
}
.rds-af-btn:hover {
border-color: var(--accent);
color: var(--accent);
}
.rds-no-signal { color: var(--text-muted); }
.rds-decoding { color: var(--accent-green); }
.rds-raw-header { display: flex; align-items: center; justify-content: space-between; gap: 0.6rem; margin-bottom: 0.3rem; }
.rds-raw-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-muted); margin-bottom: 0.3rem; }
.rds-raw-header .rds-raw-label { margin-bottom: 0; }
#rds-raw-copy-btn { height: 1.65rem; padding: 0 0.55rem; font-size: 0.72rem; }
.rds-raw { background: var(--input-bg); border: 1px solid var(--border-light); border-radius: 6px; padding: 0.5rem 0.6rem; font-size: 0.8rem; font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; color: var(--text); white-space: pre; overflow-x: auto; margin: 0; }
.cw-controls { display: flex; gap: 0.6rem; align-items: center; margin-bottom: 0.75rem; }
.cw-config { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; margin-bottom: 0.75rem; }
.cw-config label { display: flex; flex-direction: column; gap: 0.2rem; color: var(--text-muted); font-size: 0.82rem; }
.cw-config input[type="number"] { width: 5rem; padding: 0.3rem 0.4rem; font-size: 0.9rem; border: 1px solid var(--border-light); border-radius: 6px; background: var(--input-bg); color: var(--text); }
.cw-tone-picker { margin-bottom: 0.75rem; border: 1px solid var(--border-light); border-radius: 8px; background: var(--input-bg); padding: 0.5rem 0.6rem; }
.cw-tone-picker.is-auto { opacity: 0.82; }
.cw-tone-picker-head { display: flex; align-items: baseline; justify-content: space-between; gap: 0.6rem; margin-bottom: 0.35rem; color: var(--text-muted); font-size: 0.78rem; }
#cw-tone-waterfall { width: 100%; height: 56px; display: block; border-radius: 6px; background: linear-gradient(180deg, rgba(8, 14, 18, 0.92), rgba(18, 28, 36, 0.98)); cursor: crosshair; }
.cw-tone-picker.is-auto #cw-tone-waterfall { cursor: not-allowed; }
#cw-output { max-height: 360px; overflow-y: auto; border: 1px solid var(--border-light); border-radius: 6px; background: var(--input-bg); font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 0.85rem; padding: 0.4rem 0.5rem; min-height: 60px; white-space: pre-wrap; word-break: break-all; }
.cw-line { line-height: 1.5; }
.cw-signal-on { width: 10px; height: 10px; border-radius: 50%; background: var(--accent-green); box-shadow: 0 0 6px var(--accent-green); flex-shrink: 0; }
.cw-signal-off { width: 10px; height: 10px; border-radius: 50%; background: var(--border-light); flex-shrink: 0; }
.cw-config .cw-auto-label { display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.82rem; color: var(--text-muted); cursor: pointer; flex-direction: row; }
.cw-auto-label input[type="checkbox"] { margin: 0; cursor: pointer; }
.cw-config input[type="number"][readonly] { opacity: 0.6; }
.cw-config input[type="number"]:disabled { opacity: 0.58; }
button:focus-visible, input:focus-visible, select:focus-visible {
outline: 2px solid var(--accent-green);
outline-offset: 2px;
}
/* ── Scrollbars ───────────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: color-mix(in srgb, var(--border-light) 70%, transparent); border-radius: 999px; }
::-webkit-scrollbar-thumb:hover { background: color-mix(in srgb, var(--accent-green) 55%, var(--border-light)); }
* { scrollbar-width: thin; scrollbar-color: color-mix(in srgb, var(--border-light) 70%, transparent) transparent; }
@media (max-width: 1099px) {
/* Side bookmark panels need the gutter; hide when card is full-width */
.spectrum-bookmark-side { display: none !important; }
}
@media (max-width: 900px) {
.card { width: 100%; padding-left: 0.9rem; padding-right: 0.9rem; }
}
@media (max-width: 760px) {
.card {
padding:
calc(0.7rem + env(safe-area-inset-top))
calc(0.7rem + env(safe-area-inset-right))
calc(1rem + env(safe-area-inset-bottom))
calc(0.7rem + env(safe-area-inset-left));
}
button { min-height: 2.8rem; font-size: 0.95rem; }
input.status-input, select.status-input { font-size: 1.1rem; }
:root { --header-waterfall-overlap: 0rem; }
.controls-tray-scroll { overflow-x: auto; }
.controls-tray { width: 100%; min-width: 0; padding-left: 0.85rem; padding-right: 0.85rem; }
.freq-inline { gap: 0.5rem; flex-wrap: wrap; }
.header-text { width: auto; min-width: 0; flex: 0 1 auto; }
.header-main {
max-width: 100%;
padding-right: 0.65rem;
margin-left: -0.15rem;
transform: translateY(-1px);
}
.header-left { justify-content: flex-end; }
.tab-bar { flex-wrap: wrap; }
.tab-bar-left {
width: 100%;
flex-wrap: wrap;
gap: 0.7rem;
}
.tab-bar .header-main {
max-width: 100%;
margin-left: 0;
transform: none;
}
.top-bar-actions { width: 100%; justify-content: space-between; }
.header-rig-switch { width: auto; justify-content: flex-end; }
.header-rig-switch select { min-width: 6.5rem; }
.overview-toolbar { top: calc(var(--header-waterfall-overlap) + 0.15rem); }
#signal-split-control {
top: 0.35rem;
right: 0.35rem;
transform: none;
flex-direction: row;
gap: 0.32rem;
border-radius: 6px;
padding: 0.24rem 0.32rem;
}
#signal-split-slider {
writing-mode: horizontal-tb;
direction: ltr;
width: 3.6rem;
height: 1rem;
cursor: ew-resize;
}
.controls-row { grid-template-columns: 1fr auto; }
.controls-col-wfm { grid-column: 1 / -1; }
.controls-col-power { grid-column: 1 / -1; }
.controls-col.label-below-col .inline,
.controls-col.label-below-col .btn-grid { margin-top: 0; }
.wfm-controls-inline { flex-wrap: wrap; }
.ft8-controls { flex-wrap: wrap; }
#ft8-decode-toggle-btn, #ft4-decode-toggle-btn, #ft2-decode-toggle-btn, #wspr-decode-toggle-btn { white-space: nowrap; }
.jog-container { flex-wrap: wrap; }
.vfo-picker { flex-direction: column; }
.vfo-picker button { border-right: none; border-bottom: 1px solid var(--border-light); }
.vfo-picker button:last-child { border-bottom: none; }
}
@media (max-width: 640px) {
.card {
padding-bottom: calc(5.6rem + env(safe-area-inset-bottom));
}
.tab-bar {
gap: 0.6rem;
align-items: stretch;
margin-bottom: 1rem;
padding-bottom: 0.2rem;
border-bottom: none;
}
.tab-bar-left {
gap: 0.55rem;
align-items: stretch;
}
.tab-bar .header-main {
width: 100%;
max-width: 100%;
}
.tab-bar .header-logo {
height: 1.9rem;
}
/* Collapse verbose subtitles — the About tab has this info */
.tab-bar .subtitle { display: none; }
.tab-bar .title { font-size: 0.92rem; }
.tab-bar-nav {
position: fixed;
left: calc(0.6rem + env(safe-area-inset-left));
right: calc(0.6rem + env(safe-area-inset-right));
bottom: calc(0.55rem + env(safe-area-inset-bottom));
z-index: 30;
display: grid;
grid-template-columns: repeat(6, minmax(0, 1fr));
gap: 0.25rem;
padding: 0.38rem;
border: 1px solid color-mix(in srgb, var(--border-light) 82%, transparent);
border-radius: 1rem;
background: color-mix(in srgb, var(--card-bg) 90%, transparent);
backdrop-filter: blur(18px) saturate(135%);
-webkit-backdrop-filter: blur(18px) saturate(135%);
box-shadow:
0 12px 28px color-mix(in srgb, #000000 22%, transparent),
inset 0 1px 0 color-mix(in srgb, #ffffff 10%, transparent);
overflow: visible;
}
.tab {
min-height: 3.2rem;
padding: 0.35rem 0.1rem 0.3rem;
border: 1px solid transparent;
border-bottom: none;
border-radius: 0.75rem;
white-space: nowrap;
text-align: center;
font-size: 0.65rem;
font-weight: 700;
line-height: 1.1;
background: transparent;
color: var(--text-muted);
display: flex;
flex-direction: column;
align-items: center;
gap: 0.2rem;
}
.tab.active {
border-color: color-mix(in srgb, var(--accent-green) 50%, var(--border-light));
background: color-mix(in srgb, var(--btn-bg) 86%, transparent);
color: var(--text);
box-shadow: inset 0 1px 0 color-mix(in srgb, #ffffff 8%, transparent);
}
.tab-icon { display: block; }
/* Shorten long tab labels to keep bottom nav compact */
.tab[data-tab="bookmarks"] .tab-label { font-size: 0.6rem; }
.tab[data-tab="decoders"] .tab-label { font-size: 0.6rem; }
.top-bar-actions {
width: 100%;
justify-content: flex-start;
flex-wrap: wrap;
gap: 0.45rem;
}
.header-rig-switch,
.header-style-pick {
flex: 1 1 12rem;
min-width: 0;
}
.header-rig-switch select,
.header-style-pick select {
width: 100%;
min-width: 0;
}
.header-bar-btn {
flex: 1 1 calc(50% - 0.3rem);
min-width: 0;
}
#tab-main,
#tab-decoders,
#tab-map,
#tab-about {
scroll-margin-top: 0.75rem;
}
.freq-inline {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 0.5rem;
align-items: start;
}
.frequency-col {
grid-column: 1 / -1;
}
.center-frequency-col {
grid-column: 1 / -1;
min-width: 0;
}
.wavelength-col,
.unit-col,
.mult-col {
min-width: 0;
}
.wavelength-display,
.jog-step,
.jog-mult {
width: 100%;
}
.jog-step button,
.jog-mult button {
flex: 1 1 0;
}
.signal,
.meter {
flex-wrap: wrap;
}
.signal-value,
.meter-value {
min-width: 0;
width: 100%;
text-align: left;
}
.signal-measure {
flex-wrap: wrap;
}
.signal-measure button {
flex: 1 1 8rem;
}
.signal-measure #sig-result {
width: 100%;
}
#spectrum-controls,
#spectrum-bw-row,
#spectrum-level-row {
display: grid;
grid-template-columns: minmax(0, 1fr);
justify-content: stretch;
}
#spectrum-controls {
gap: 0.5rem;
padding-top: 0.45rem;
}
.spectrum-edge-shift {
width: 0.95rem;
}
.spectrum-bookmark-side .spectrum-bookmark-chip {
font-size: 0.58rem;
padding: 2px 6px;
}
.spectrum-edge-shift-left {
left: 0.2rem;
}
.spectrum-edge-shift-right {
right: 0.2rem;
}
#spectrum-bw-row,
#spectrum-level-row {
gap: 0.4rem;
}
#spectrum-bw-label,
#spectrum-floor-label,
#spectrum-gamma-label,
#spectrum-peak-hold-label {
width: 100%;
justify-content: space-between;
}
#spectrum-bw-input,
#spectrum-floor-input,
#overview-peak-hold {
width: 100%;
min-width: 0;
box-sizing: border-box;
}
.aprs-controls,
.ft8-controls,
.cw-controls {
flex-wrap: wrap;
align-items: stretch;
}
.ais-summary {
grid-template-columns: minmax(0, 1fr);
}
.aprs-summary {
grid-template-columns: minmax(0, 1fr);
}
#subtab-ais {
min-height: calc(100vh - 14rem);
}
#subtab-vdes {
min-height: calc(100vh - 14rem);
}
#subtab-aprs {
min-height: calc(100vh - 14rem);
}
#aprs-packets {
min-height: calc(100vh - 26rem);
}
#ais-messages {
min-height: calc(100vh - 22rem);
}
#vdes-messages {
min-height: calc(100vh - 22rem);
}
.aprs-details-grid {
grid-template-columns: minmax(0, 1fr);
gap: 0.14rem;
}
.aprs-controls > button,
.ft8-controls > button,
.cw-controls > button {
flex: 1 1 auto;
}
.ft8-filter {
min-width: 0;
width: 100%;
flex-basis: 100%;
}
.map-overlay-panel {
top: 0.55rem;
left: 0.55rem;
width: calc(100% - 1.1rem);
max-height: min(16.5rem, calc(100% - 1.1rem));
padding: 0.6rem 0.65rem;
border-radius: 0.7rem;
}
.map-corner-controls {
top: 0.55rem;
right: 0.55rem;
}
.map-band-legend {
left: 0.55rem;
bottom: 0.55rem;
width: min(12rem, calc(100% - 1.1rem));
max-height: min(36%, 13rem);
padding: 0.55rem 0.6rem;
border-radius: 0.7rem;
}
.map-band-legend-list {
grid-template-columns: repeat(auto-fit, minmax(4.8rem, 1fr));
}
.map-locator-filter-group {
align-items: stretch;
}
.map-qso-summary {
padding: 0.8rem 0.85rem 0.9rem;
}
.map-qso-summary-list {
grid-template-columns: 1fr;
}
.map-locator-filter-label {
width: 100%;
min-width: 0;
padding-top: 0;
}
.map-locator-empty {
padding-top: 0;
}
.rds-grid {
grid-template-columns: minmax(0, 1fr);
gap: 0.55rem;
}
.rds-field {
display: grid;
grid-template-columns: minmax(0, 1fr);
gap: 0.16rem;
padding: 0.45rem 0.55rem;
border: 1px solid color-mix(in srgb, var(--border-light) 72%, transparent);
border-radius: 0.6rem;
background: color-mix(in srgb, var(--input-bg) 84%, transparent);
}
.rds-label {
white-space: normal;
}
.rds-raw-header {
flex-wrap: wrap;
}
#rds-raw-copy-btn {
width: 100%;
}
.about-table,
.about-table tbody,
.about-table tr,
.about-table td {
display: block;
width: 100%;
box-sizing: border-box;
}
.about-table tr {
padding: 0.35rem 0;
border-bottom: 1px solid var(--border);
}
.about-table tr:last-child {
border-bottom: none;
}
.about-table td {
padding: 0.15rem 0;
border-bottom: none;
}
.about-table td:first-child {
width: 100%;
}
.footer {
flex-direction: column;
align-items: flex-start;
gap: 0.55rem;
}
/* ── Bookmark card layout ──────────────────────────────────────────── */
#bm-table-wrap { overflow-x: hidden; }
.bm-table,
.bm-table tbody { display: block; }
.bm-table thead { display: none; }
.bm-table tr {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 0.22rem 0.5rem;
border: 1px solid color-mix(in srgb, var(--border-light) 72%, transparent);
border-radius: 0.7rem;
padding: 0.6rem 0.7rem;
margin-bottom: 0.45rem;
background: color-mix(in srgb, var(--btn-bg) 35%, transparent);
}
.bm-table tr:hover td { background: transparent; }
.bm-table td {
display: flex;
flex-direction: column;
gap: 0.05rem;
border-bottom: none;
padding: 0.08rem 0;
font-size: 0.82rem;
word-break: break-word;
}
.bm-table td::before {
font-size: 0.62rem;
font-weight: 700;
letter-spacing: 0.05em;
text-transform: uppercase;
color: var(--text-muted);
}
.bm-col-sel { grid-column: 1 / -1; display: flex; align-items: center; padding: 0; }
.bm-col-sel::before { display: none; }
.bm-col-name { grid-column: 1 / -1; font-weight: 600; font-size: 0.9rem; }
.bm-col-name::before { content: "Bookmark"; }
.bm-col-freq::before { content: "Frequency"; }
.bm-col-mode::before { content: "Mode"; }
.bm-col-bw::before { content: "Bandwidth"; }
.bm-col-loc::before { content: "Locator"; }
.bm-col-cat::before { content: "Category"; }
.bm-col-dec::before { content: "Decoders"; }
.bm-col-cmt { grid-column: 1 / -1; }
.bm-col-cmt::before { content: "Comment"; }
.bm-col-act { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: 0.4rem; padding-top: 0.25rem; }
.bm-col-act::before { display: none; }
.bm-col-act button { flex: 1 1 auto; min-height: 2.4rem; font-size: 0.8rem; }
}
/* ── Spectrum display ─────────────────────────────────────────────────── */
#spectrum-panel {
margin-bottom: 0;
}
.spectrum-resizing,
.spectrum-resizing * {
cursor: ns-resize !important;
user-select: none !important;
}
.spectrum-wrap {
position: relative;
width: 100%;
user-select: none;
}
#spectrum-canvas {
display: block;
width: 100%;
height: var(--spectrum-plot-height);
background: var(--spectrum-bg);
border-radius: 6px 6px 0 0;
cursor: crosshair;
touch-action: none;
}
#spectrum-db-axis {
position: absolute;
top: 0;
left: 0;
width: 3rem;
height: var(--spectrum-plot-height);
pointer-events: none;
z-index: 7;
}
#spectrum-db-axis span {
position: absolute;
left: 0.22rem;
transform: translateY(-50%);
font-size: 0.62rem;
line-height: 1;
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
color: var(--text-muted);
font-weight: 700;
letter-spacing: 0.01em;
text-shadow: 0 1px 2px color-mix(in srgb, var(--bg) 65%, transparent);
white-space: nowrap;
}
.spectrum-edge-shift {
position: absolute;
top: 50%;
transform: translateY(-50%);
z-index: 8;
width: 1.4rem;
height: 100%;
padding: 0;
border: none;
background: none;
color: color-mix(in srgb, var(--text-muted) 78%, var(--accent-yellow));
display: inline-flex;
align-items: center;
justify-content: center;
font-size: 0;
line-height: 1;
cursor: pointer;
appearance: none;
-webkit-appearance: none;
transition: color 120ms ease, opacity 120ms ease;
opacity: 0.92;
}
.spectrum-edge-shift::before {
content: "";
width: 0;
height: 0;
border-top: 0.24rem solid transparent;
border-bottom: 0.24rem solid transparent;
}
.spectrum-edge-shift-left::before {
border-right: 0.38rem solid currentColor;
}
.spectrum-edge-shift-right::before {
border-left: 0.38rem solid currentColor;
}
.spectrum-edge-shift:hover {
color: var(--accent-yellow);
opacity: 1;
}
.spectrum-edge-shift:active {
transform: translateY(-50%);
color: var(--text-heading);
}
.spectrum-edge-shift-left {
left: 0.24rem;
}
.spectrum-edge-shift-right {
right: 0.24rem;
}
#spectrum-freq-axis {
position: relative;
height: 18px;
width: 100%;
font-size: 0.7rem;
color: var(--text-muted);
background: var(--bg-secondary);
border-radius: 0 0 6px 6px;
border: 1px solid var(--border);
border-top: none;
}
#spectrum-size-grip {
position: relative;
height: 1.1rem;
margin: 0.18rem 0 0.42rem;
cursor: ns-resize;
touch-action: none;
border-radius: 999px;
}
#spectrum-size-grip::before {
content: "";
position: absolute;
left: 50%;
top: 50%;
width: 4.2rem;
height: 0.3rem;
transform: translate(-50%, -50%);
border-radius: 999px;
border: 1px solid color-mix(in srgb, var(--border-light) 76%, transparent);
background: color-mix(in srgb, var(--btn-bg) 78%, transparent);
}
#spectrum-size-grip:hover::before {
border-color: color-mix(in srgb, var(--accent-yellow) 55%, var(--border-light));
background: color-mix(in srgb, var(--accent-yellow) 22%, var(--btn-bg));
}
#spectrum-freq-axis span {
position: absolute;
transform: translateX(-50%);
white-space: nowrap;
top: 2px;
font-weight: 700;
pointer-events: none;
}
#spectrum-bookmark-axis {
position: absolute;
top: calc(-1 * var(--overview-plot-height));
left: 0;
right: 0;
z-index: 8;
height: 0;
overflow: hidden;
font-size: 0.68rem;
background: transparent;
transition: height 80ms ease;
}
#spectrum-bookmark-axis.bm-axis-visible {
height: 38px;
overflow: visible;
}
.spectrum-bookmark-chip {
position: absolute;
transform: translateX(-50%);
top: 2px;
cursor: pointer;
font-weight: 600;
font-size: 0.66rem;
background: var(--bm-cat-bg, var(--accent-yellow));
color: var(--bm-cat-fg, #1a202c);
border: 1px solid var(--bm-cat-bg, var(--accent-yellow));
border-radius: 3px;
padding: 2px 8px;
max-width: 130px;
overflow: hidden;
line-height: 1.4;
display: inline-flex;
align-items: flex-start;
gap: 4px;
}
.spectrum-bookmark-chip:hover {
filter: brightness(1.15);
}
.spectrum-bookmark-chip .spectrum-bookmark-name {
white-space: normal;
word-break: break-word;
line-height: 1.2;
}
.spectrum-bookmark-side {
position: absolute;
top: calc(var(--spectrum-plot-height) / 2);
transform: translateY(-50%);
z-index: 7;
width: var(--spectrum-bookmark-side-width);
display: none;
flex-direction: column;
gap: 0.28rem;
}
.spectrum-bookmark-side.bm-side-visible {
display: flex;
}
.spectrum-bookmark-side-left {
left: calc(-1 * var(--spectrum-bookmark-side-offset));
align-items: flex-end;
}
.spectrum-bookmark-side-right {
right: calc(-1 * var(--spectrum-bookmark-side-offset));
align-items: flex-start;
}
.spectrum-bookmark-side .spectrum-bookmark-chip {
position: relative;
top: auto;
left: auto;
transform: none;
max-width: 100%;
}
.spectrum-bookmark-chip-side {
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 0.16rem;
width: 100%;
min-height: 0;
padding: 0.38rem 0.5rem 0.42rem;
border-radius: 0.55rem;
white-space: normal;
line-height: 1.1;
}
.spectrum-bookmark-side-head {
display: inline-flex;
align-items: center;
gap: 0.32rem;
min-width: 0;
width: 100%;
}
.spectrum-bookmark-chip-side .bm-icon-svg {
flex: 0 0 auto;
width: 0.5rem;
height: 0.72rem;
opacity: 0.95;
}
.spectrum-bookmark-chip-side .spectrum-bookmark-freq,
.spectrum-bookmark-chip-side .spectrum-bookmark-name {
display: block;
max-width: 100%;
min-width: 0;
}
.spectrum-bookmark-chip-side .spectrum-bookmark-freq {
font-size: 0.54rem;
font-weight: 700;
letter-spacing: 0.04em;
text-transform: uppercase;
opacity: 0.9;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.spectrum-bookmark-chip-side .spectrum-bookmark-name {
width: 100%;
font-size: 0.64rem;
font-weight: 600;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
line-height: 1.22;
}
.bm-icon-svg path {
fill: var(--bm-cat-fg, #1a202c);
}
#spectrum-tooltip {
display: none;
position: absolute;
pointer-events: none;
background: rgba(10,15,24,0.85);
color: #00e676;
font-size: 0.75rem;
font-family: monospace;
padding: 2px 6px;
border-radius: 4px;
border: 1px solid rgba(0,230,118,0.3);
white-space: nowrap;
z-index: 10;
}
#spectrum-controls {
display: flex;
align-items: center;
justify-content: space-between;
padding: 3px 4px 0;
gap: 0.6rem;
font-size: 0.78rem;
color: var(--text-muted);
}
#spectrum-bw-row {
display: flex;
align-items: center;
flex-wrap: wrap;
gap: 0.4rem;
}
#spectrum-bw-label {
display: flex;
align-items: center;
gap: 0.3rem;
font-size: 0.75rem;
color: var(--text-muted);
min-width: 0;
}
#spectrum-bw-input {
width: 4.5rem;
padding: 1px 4px;
font-size: 0.75rem;
border: 1px solid var(--border);
border-radius: 4px;
background: var(--input-bg);
color: var(--text);
text-align: right;
height: 1.5rem;
}
#spectrum-bw-set-btn,
#spectrum-bw-auto-btn,
#spectrum-bw-sweet-btn {
height: 1.5rem;
min-height: 0;
padding: 0 8px;
font-size: 0.73rem;
}
#spectrum-level-row {
display: flex;
align-items: center;
gap: 0.4rem;
}
#spectrum-floor-label {
display: flex;
align-items: center;
gap: 0.3rem;
font-size: 0.75rem;
color: var(--text-muted);
}
#spectrum-floor-input {
width: 3.4rem;
padding: 1px 4px;
font-size: 0.75rem;
border: 1px solid var(--border);
border-radius: 4px;
background: var(--input-bg);
color: var(--text);
text-align: right;
height: 1.5rem;
}
#spectrum-auto-btn {
height: 1.5rem;
min-height: 0;
padding: 0 8px;
font-size: 0.73rem;
}
#spectrum-gamma-label {
display: flex;
align-items: center;
gap: 0.3rem;
font-size: 0.75rem;
color: var(--text-muted);
}
#spectrum-gamma-input {
width: 5rem;
height: 1.5rem;
cursor: pointer;
}
#spectrum-gamma-value {
font-size: 0.72rem;
min-width: 1.6rem;
text-align: right;
}
.spectrum-hint-mouse,
.spectrum-hint-touch {
font-size: 0.68rem;
color: var(--text-muted);
text-align: right;
margin-top: 2px;
opacity: 0.6;
}
/* Show correct hint based on input device */
.spectrum-hint-touch { display: none; }
@media (hover: none) and (pointer: coarse) {
.spectrum-hint-mouse { display: none; }
.spectrum-hint-touch { display: block; }
}
/* ── Phone layout (≤ 520px) ───────────────────────────────────────────── */
@media (max-width: 520px) {
/* Single-column controls: jog first, then mode, then power */
.controls-row {
grid-template-columns: 1fr;
}
.controls-col-center {
order: -1;
justify-self: center;
width: auto;
}
.controls-col-center::after { display: none; }
.controls-col.label-below-col .inline,
.controls-col.label-below-col .btn-grid { margin-top: 0; }
/* Scale frequency display to fit narrow screens */
#freq { font-size: clamp(1.3rem, 6vw, 2rem); }
/* Wider volume sliders for touch */
.vol-slider { width: 100%; flex: 1 1 auto; }
.vol-label {
flex-direction: row;
align-items: center;
gap: 0.5rem;
width: 100%;
justify-content: space-between;
}
.vol-pct { min-width: 2.4rem; text-align: right; }
.vol-slider::-webkit-slider-thumb { width: 22px; height: 22px; }
.vol-slider::-moz-range-thumb { width: 22px; height: 22px; }
#audio-row .inline {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 0.55rem;
align-items: stretch;
}
#rx-audio-btn,
#tx-audio-btn,
#audio-level,
#audio-status,
#sdr-squelch-wrap {
grid-column: 1 / -1;
}
#audio-level {
min-width: 0;
height: 14px;
}
/* Spectrum control inputs and buttons: meet minimum tap-target size */
#spectrum-bw-input,
#spectrum-floor-input {
height: 2.2rem;
font-size: 0.82rem;
}
#spectrum-bw-set-btn,
#spectrum-bw-auto-btn,
#spectrum-bw-sweet-btn,
#spectrum-auto-btn {
height: 2.2rem;
min-height: 0;
padding: 0 10px;
font-size: 0.82rem;
}
}
/* ── Arctic style ─────────────────────────────────────────────────────── */
[data-style="arctic"] {
--bg: #242933;
--card-bg: #2e3440;
--input-bg: #242933;
--border: #3b4252;
--border-light: #4c566a;
--text: #d8dee9;
--text-muted: #8a9ab0;
--text-heading: #eceff4;
--btn-bg: #3b4252;
--btn-border: #5e6f88;
--accent-green: #88c0d0;
--accent-yellow: #ebcb8b;
--accent-red: #bf616a;
--jog-hi: #434c5e;
--jog-lo: #3b4252;
--jog-shadow: rgba(0,0,0,0.40);
--jog-inset: rgba(255,255,255,0.06);
--audio-level-bg: #2e3440;
--audio-level-border: #4c566a;
--audio-level-fill-start: #88c0d0;
--audio-level-fill-end: #ebcb8b;
--filter-bg: #3b4252;
--filter-fg: #d8dee9;
--filter-border: #5e6f88;
--wavelength-fg: #7a8ea8;
--spectrum-bg: #1e2530;
}
[data-style="arctic"][data-theme="light"] {
--bg: #e5e9f0;
--card-bg: #eceff4;
--input-bg: #d8dee9;
--border: #c5ccd8;
--border-light: #a8b2c0;
--text: #2e3440;
--text-muted: #4c566a;
--text-heading: #2e3440;
--btn-bg: #d8dee9;
--btn-border: #8fa3b8;
--accent-green: #5e81ac;
--accent-yellow: #c07a22;
--accent-red: #bf616a;
--jog-hi: #d8dee9;
--jog-lo: #c2cbd8;
--jog-shadow: rgba(46,52,64,0.18);
--jog-inset: rgba(255,255,255,0.70);
--audio-level-bg: #d0d6e0;
--audio-level-border: #a8b2c0;
--audio-level-fill-start: #5e81ac;
--audio-level-fill-end: #c07a22;
--filter-bg: #d8dee9;
--filter-fg: #2e3440;
--filter-border: #8fa3b8;
--wavelength-fg: #5a6a80;
--spectrum-bg: #dde1e9;
}
/* ── Lime style ───────────────────────────────────────────────────────── */
[data-style="lime"] {
--bg: #1c1c17;
--card-bg: #272822;
--input-bg: #1c1c17;
--border: #3e3d32;
--border-light: #5c5c45;
--text: #f8f8f2;
--text-muted: #908980;
--text-heading: #f8f8f2;
--btn-bg: #3e3d32;
--btn-border: #75715e;
--accent-green: #a6e22e;
--accent-yellow: #e6db74;
--accent-red: #f92672;
--jog-hi: #49483e;
--jog-lo: #3e3d32;
--jog-shadow: rgba(0,0,0,0.45);
--jog-inset: rgba(255,255,255,0.05);
--audio-level-bg: #272822;
--audio-level-border: #5c5c45;
--audio-level-fill-start: #a6e22e;
--audio-level-fill-end: #e6db74;
--filter-bg: #3e3d32;
--filter-fg: #f8f8f2;
--filter-border: #75715e;
--wavelength-fg: #9c8f78;
--spectrum-bg: #181815;
}
[data-style="lime"][data-theme="light"] {
--bg: #f5f0e4;
--card-bg: #fdf9f2;
--input-bg: #ede8d8;
--border: #d8d0bb;
--border-light: #c0b89e;
--text: #272822;
--text-muted: #6e6a56;
--text-heading: #272822;
--btn-bg: #ede8d8;
--btn-border: #b0a888;
--accent-green: #5f8700;
--accent-yellow: #9a7200;
--accent-red: #c60052;
--jog-hi: #ede8d8;
--jog-lo: #ddd8c8;
--jog-shadow: rgba(39,40,34,0.18);
--jog-inset: rgba(255,255,255,0.75);
--audio-level-bg: #ede8d8;
--audio-level-border: #c0b89e;
--audio-level-fill-start: #5f8700;
--audio-level-fill-end: #9a7200;
--filter-bg: #ede8d8;
--filter-fg: #272822;
--filter-border: #b0a888;
--wavelength-fg: #7a7260;
--spectrum-bg: #ede8d8;
}
/* ── Contrast style ───────────────────────────────────────────────────── */
[data-style="contrast"] {
--bg: #000000;
--card-bg: #0a0a0a;
--input-bg: #111111;
--border: #333333;
--border-light: #555555;
--text: #ffffff;
--text-muted: #bbbbbb;
--text-heading: #ffffff;
--btn-bg: #1a1a1a;
--btn-border: #666666;
--accent-green: #00ff88;
--accent-yellow: #ffcc00;
--accent-red: #ff3344;
--jog-hi: #2a2a2a;
--jog-lo: #1a1a1a;
--jog-shadow: rgba(0,0,0,0.60);
--jog-inset: rgba(255,255,255,0.08);
--audio-level-bg: #111111;
--audio-level-border: #555555;
--audio-level-fill-start: #00ff88;
--audio-level-fill-end: #ffcc00;
--filter-bg: #1a1a1a;
--filter-fg: #ffffff;
--filter-border: #666666;
--wavelength-fg: #aaaaaa;
--spectrum-bg: #000000;
}
[data-style="contrast"][data-theme="light"] {
--bg: #ffffff;
--card-bg: #f4f4f4;
--input-bg: #e8e8e8;
--border: #cccccc;
--border-light: #999999;
--text: #000000;
--text-muted: #333333;
--text-heading: #000000;
--btn-bg: #e0e0e0;
--btn-border: #777777;
--accent-green: #005cc5;
--accent-yellow: #cc5500;
--accent-red: #cc0000;
--jog-hi: #e0e0e0;
--jog-lo: #cccccc;
--jog-shadow: rgba(0,0,0,0.25);
--jog-inset: rgba(255,255,255,0.80);
--audio-level-bg: #e8e8e8;
--audio-level-border: #999999;
--audio-level-fill-start: #005cc5;
--audio-level-fill-end: #cc5500;
--filter-bg: #e8e8e8;
--filter-fg: #000000;
--filter-border: #999999;
--wavelength-fg: #444444;
--spectrum-bg: #f4f4f4;
}
/* ── Neon Disco style ─────────────────────────────────────────────────── */
[data-style="neon-disco"] {
--bg: #0d0015;
--card-bg: #180026;
--input-bg: #100018;
--border: #3d0060;
--border-light: #7700bb;
--text: #f5e0ff;
--text-muted: #b070d8;
--text-heading: #fce8ff;
--btn-bg: #2a0042;
--btn-border: #9900dd;
--accent-green: #ff10e0;
--accent-yellow: #39ff14;
--accent-red: #ff1460;
--jog-hi: #360058;
--jog-lo: #280042;
--jog-shadow: rgba(0,0,0,0.65);
--jog-inset: rgba(255,16,224,0.08);
--audio-level-bg: #180026;
--audio-level-border: #7700bb;
--audio-level-fill-start: #ff10e0;
--audio-level-fill-end: #39ff14;
--filter-bg: #2a0042;
--filter-fg: #f5e0ff;
--filter-border: #9900dd;
--wavelength-fg: #9055b8;
--spectrum-bg: #090010;
}
[data-style="neon-disco"][data-theme="light"] {
--bg: #faeeff;
--card-bg: #fff4ff;
--input-bg: #f2e0ff;
--border: #dda8f5;
--border-light: #cc80e8;
--text: #1a0030;
--text-muted: #7a30a0;
--text-heading: #1a0030;
--btn-bg: #f0d8ff;
--btn-border: #bb80dd;
--accent-green: #cc00a8;
--accent-yellow: #1f8800;
--accent-red: #cc0044;
--jog-hi: #f0d8ff;
--jog-lo: #e2c8f5;
--jog-shadow: rgba(60,0,100,0.18);
--jog-inset: rgba(255,255,255,0.72);
--audio-level-bg: #f0d8ff;
--audio-level-border: #cc80e8;
--audio-level-fill-start: #cc00a8;
--audio-level-fill-end: #1f8800;
--filter-bg: #f0d8ff;
--filter-fg: #1a0030;
--filter-border: #bb80dd;
--wavelength-fg: #7030a0;
--spectrum-bg: #f0d8ff;
}
/* ============================================================
Bookmarks tab
============================================================ */
.bm-toolbar {
display: flex;
align-items: center;
gap: 0.6rem;
padding: 0.6rem 0.75rem 0.4rem;
flex-wrap: wrap;
}
.bm-add-btn {
white-space: nowrap;
}
#sch-entry-form .bm-form-grid {
gap: 0.75rem 0.75rem;
}
#sch-entry-form .bm-label {
gap: 0.35rem;
}
#bm-form-wrap,
#sch-entry-form-wrap {
position: fixed;
inset: 0;
z-index: 120;
padding: 1.25rem;
background: rgba(7, 12, 18, 0.72);
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
align-items: center;
justify-content: center;
}
.bm-form {
box-sizing: border-box;
background: var(--card-bg);
border: 1px solid var(--border-light);
border-radius: 0.8rem;
padding: 1rem 1.1rem;
margin: 0;
width: min(46rem, calc(100vw - 2.5rem));
max-height: min(85vh, 42rem);
overflow-x: hidden;
overflow-y: auto;
box-shadow: 0 1.2rem 2.6rem rgba(0, 0, 0, 0.38);
}
.bm-form-title {
font-weight: 700;
margin-bottom: 0.65rem;
font-size: 0.95rem;
color: var(--text-heading);
}
.bm-form-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(13rem, 1fr));
gap: 0.5rem 0.75rem;
}
.bm-label {
display: flex;
flex-direction: column;
gap: 0.2rem;
font-size: 0.78rem;
color: var(--text-muted);
min-width: 0;
}
.bm-label input,
.bm-label select {
font-size: 0.88rem;
padding: 0.35rem 0.5rem;
}
.bm-label-wide {
grid-column: 1 / -1;
}
.bm-form-actions {
display: flex;
gap: 0.5rem;
margin-top: 0.75rem;
justify-content: flex-end;
}
.bm-save-btn,
#bm-form-cancel,
#sch-entry-form-cancel {
background: var(--accent-green);
color: #fff;
border: none;
border-radius: 0.35rem;
padding: 0.4rem 1rem;
font-weight: 600;
cursor: pointer;
}
.bm-save-btn:hover,
#bm-form-cancel:hover,
#sch-entry-form-cancel:hover {
opacity: 0.88;
}
#bm-form-cancel,
#sch-entry-form-cancel {
background: var(--btn-bg);
color: var(--text);
border: 1px solid var(--btn-border);
}
.bm-decoder-checks {
display: flex;
flex-wrap: wrap;
gap: 0.6rem;
min-height: 2.2rem;
padding: 0.5rem 0.65rem;
border: 1px solid var(--border-light);
border-radius: 0.45rem;
background: var(--input-bg);
}
.bm-decoder-check {
display: inline-flex;
align-items: center;
gap: 0.35rem;
color: var(--text);
font-size: 0.84rem;
}
.bm-decoder-check input {
margin: 0;
}
.bm-table {
width: 100%;
border-collapse: collapse;
font-size: 0.82rem;
margin: 0 0 0.5rem;
}
.bm-table th {
text-align: left;
padding: 0.35rem 0.6rem;
border-bottom: 1px solid var(--border);
color: var(--text-muted);
font-weight: 600;
white-space: nowrap;
}
.bm-table td {
padding: 0.35rem 0.6rem;
border-bottom: 1px solid var(--border);
vertical-align: middle;
}
.bm-table tr:hover td {
background: var(--btn-bg);
}
.bm-col-freq,
.bm-col-bw {
white-space: nowrap;
font-variant-numeric: tabular-nums;
}
.bm-col-mode,
.bm-col-dec {
white-space: nowrap;
}
.bm-col-act {
white-space: nowrap;
}
.bm-col-act button {
font-size: 0.78rem;
padding: 0.2rem 0.5rem;
margin-right: 0.25rem;
border-radius: 0.25rem;
border: 1px solid var(--btn-border);
background: var(--btn-bg);
color: var(--text);
cursor: pointer;
}
.bm-col-act button:hover {
background: var(--border-light);
}
.bm-col-sel {
width: 1.8rem;
text-align: center;
padding-left: 0.4rem;
padding-right: 0;
}
.bm-del-btn,
#bm-del-selected-btn {
color: var(--accent-red) !important;
border-color: var(--accent-red) !important;
}
#bm-del-selected-btn {
font-size: 0.78rem;
padding: 0.25rem 0.6rem;
border-radius: 0.25rem;
border: 1px solid var(--accent-red);
background: var(--btn-bg);
cursor: pointer;
}
.bm-move-wrap {
display: inline-flex;
align-items: center;
gap: 0.35rem;
}
.bm-toolbar-btn {
white-space: nowrap;
font-size: 0.78rem;
padding: 0.25rem 0.6rem;
border-radius: 0.25rem;
border: 1px solid var(--border-light);
background: var(--btn-bg);
color: var(--text-heading);
cursor: pointer;
}
.bm-empty {
padding: 2rem 1rem;
text-align: center;
color: var(--text-muted);
font-size: 0.9rem;
}
.bm-paginator {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.8rem;
padding: 0.9rem 0.2rem 0;
}
.bm-page-summary,
.bm-page-indicator {
color: var(--text-muted);
font-size: 0.88rem;
}
.bm-page-controls {
display: flex;
align-items: center;
gap: 0.55rem;
}
.bm-page-controls button {
min-width: 6.4rem;
}
.bm-page-controls button:disabled {
opacity: 0.45;
cursor: default;
}
/* ── Donald style ─────────────────────────────────────────────────────── */
[data-style="golden-rain"] {
--bg: #100c06;
--card-bg: #1a1209;
--input-bg: #140f08;
--border: #3f2d18;
--border-light: #6d4e23;
--text: #f3e4bf;
--text-muted: #aa9062;
--text-heading: #fff0ca;
--btn-bg: #2a1c0d;
--btn-border: #7c5928;
--accent-green: #dfac48;
--accent-yellow: #f4cd74;
--accent-red: #cf7d32;
--jog-hi: #392610;
--jog-lo: #24170b;
--jog-shadow: rgba(0,0,0,0.64);
--jog-inset: rgba(255,219,138,0.06);
--audio-level-bg: #1c130a;
--audio-level-border: #6d4e23;
--audio-level-fill-start: #dfac48;
--audio-level-fill-end: #f4cd74;
--filter-bg: #2b1d0f;
--filter-fg: #f3e4bf;
--filter-border: #7c5928;
--wavelength-fg: #ab8b52;
--spectrum-bg: #120d07;
}
[data-style="golden-rain"][data-theme="light"] {
--bg: #f7efdd;
--card-bg: #fff9ec;
--input-bg: #f0e3c6;
--border: #d4bc8a;
--border-light: #b99243;
--text: #3f2c10;
--text-muted: #7f6640;
--text-heading: #3a2609;
--btn-bg: #f0e3c6;
--btn-border: #b99243;
--accent-green: #a96d00;
--accent-yellow: #c88a16;
--accent-red: #b65316;
--jog-hi: #f2e5c8;
--jog-lo: #e3d1a8;
--jog-shadow: rgba(82,55,14,0.16);
--jog-inset: rgba(255,255,255,0.76);
--audio-level-bg: #f0e3c6;
--audio-level-border: #c5a15d;
--audio-level-fill-start: #a96d00;
--audio-level-fill-end: #d4a13a;
--filter-bg: #f0e3c6;
--filter-fg: #3f2c10;
--filter-border: #b99243;
--wavelength-fg: #87663a;
--spectrum-bg: #f5ecd9;
}
/* ── Amber style ──────────────────────────────────────────────────────── */
[data-style="amber"] {
--bg: #120706;
--card-bg: #1b0c0a;
--input-bg: #180907;
--border: #4c1a12;
--border-light: #7a2e1a;
--text: #ffe7d2;
--text-muted: #c78361;
--text-heading: #fff3e7;
--btn-bg: #2c110d;
--btn-border: #8f3a20;
--accent-green: #ff6f1f;
--accent-yellow: #ffb347;
--accent-red: #ff4a24;
--jog-hi: #381510;
--jog-lo: #24100c;
--jog-shadow: rgba(0,0,0,0.62);
--jog-inset: rgba(255,164,76,0.07);
--audio-level-bg: #1f0d0a;
--audio-level-border: #7a2e1a;
--audio-level-fill-start: #ff4a24;
--audio-level-fill-end: #ffb347;
--filter-bg: #2b120d;
--filter-fg: #ffe7d2;
--filter-border: #8f3a20;
--wavelength-fg: #d38d6a;
--spectrum-bg: #140907;
}
[data-style="amber"][data-theme="light"] {
--bg: #fff3ea;
--card-bg: #fff7f0;
--input-bg: #ffe9da;
--border: #efc7b1;
--border-light: #d9a487;
--text: #42180d;
--text-muted: #8a4b31;
--text-heading: #2f120a;
--btn-bg: #ffe2cf;
--btn-border: #cc8563;
--accent-green: #d24c12;
--accent-yellow: #d88400;
--accent-red: #c53114;
--jog-hi: #ffe2cf;
--jog-lo: #ffd5bc;
--jog-shadow: rgba(108,44,15,0.18);
--jog-inset: rgba(255,255,255,0.72);
--audio-level-bg: #ffe7d7;
--audio-level-border: #d9a487;
--audio-level-fill-start: #c53114;
--audio-level-fill-end: #d88400;
--filter-bg: #ffe2cf;
--filter-fg: #42180d;
--filter-border: #cc8563;
--wavelength-fg: #9a5a3a;
--spectrum-bg: #fff0e4;
}
/* ── Fire style ───────────────────────────────────────────────────────── */
[data-style="fire"] {
--bg: #140406;
--card-bg: #1d0708;
--input-bg: #1a0607;
--border: #551015;
--border-light: #8f1f26;
--text: #ffe6df;
--text-muted: #cf8d82;
--text-heading: #fff4ef;
--btn-bg: #2d0c0d;
--btn-border: #9d262b;
--accent-green: #d13a32;
--accent-yellow: #ff6a3d;
--accent-red: #c10f1f;
--jog-hi: #390f11;
--jog-lo: #25090b;
--jog-shadow: rgba(0,0,0,0.64);
--jog-inset: rgba(255,120,100,0.06);
--audio-level-bg: #22090b;
--audio-level-border: #8f1f26;
--audio-level-fill-start: #c10f1f;
--audio-level-fill-end: #ff6a3d;
--filter-bg: #2d0c0d;
--filter-fg: #ffe6df;
--filter-border: #9d262b;
--wavelength-fg: #d78d78;
--spectrum-bg: #150508;
}
[data-style="fire"][data-theme="light"] {
--bg: #fdf0ea;
--card-bg: #fff6f1;
--input-bg: #ffe5db;
--border: #e9b8aa;
--border-light: #d27c66;
--text: #4a110d;
--text-muted: #8a493f;
--text-heading: #340b08;
--btn-bg: #ffd9cc;
--btn-border: #c85b47;
--accent-green: #ba2d24;
--accent-yellow: #d95518;
--accent-red: #a80f1c;
--jog-hi: #ffd9cc;
--jog-lo: #ffcab9;
--jog-shadow: rgba(110,35,20,0.18);
--jog-inset: rgba(255,255,255,0.74);
--audio-level-bg: #ffe2d7;
--audio-level-border: #d27c66;
--audio-level-fill-start: #a80f1c;
--audio-level-fill-end: #d95518;
--filter-bg: #ffd9cc;
--filter-fg: #4a110d;
--filter-border: #c85b47;
--wavelength-fg: #9d5547;
--spectrum-bg: #ffede5;
}
/* ── Phosphor style ───────────────────────────────────────────────────── */
/* Classic green-phosphor CRT terminal aesthetic */
[data-style="phosphor"] {
--bg: #030a03;
--card-bg: #060e06;
--input-bg: #030a03;
--border: #0f2e0f;
--border-light: #1a4a1a;
--text: #a8e6a8;
--text-muted: #5a9a5a;
--text-heading: #c8f0c8;
--btn-bg: #0a1e0a;
--btn-border: #1e4a1e;
--accent-green: #39ff14;
--accent-yellow: #b8f060;
--accent-red: #ff4444;
--jog-hi: #0e2a0e;
--jog-lo: #081808;
--jog-shadow: rgba(0,0,0,0.65);
--jog-inset: rgba(57,255,20,0.07);
--audio-level-bg: #060e06;
--audio-level-border: #1a4a1a;
--audio-level-fill-start: #39ff14;
--audio-level-fill-end: #b8f060;
--filter-bg: #0a1e0a;
--filter-fg: #a8e6a8;
--filter-border: #1e4a1e;
--wavelength-fg: #4a8a4a;
--spectrum-bg: #010501;
}
[data-style="phosphor"] #freq {
color: #39ff14;
text-shadow: 0 0 8px rgba(57,255,20,0.55), 0 0 20px rgba(57,255,20,0.2);
}
[data-style="phosphor"] .signal-bar-fill,
[data-style="phosphor"] .meter-fill {
background: linear-gradient(90deg, #39ff14, #b8f060);
box-shadow: 0 0 6px rgba(57,255,20,0.45);
}
[data-style="phosphor"][data-theme="light"] {
--bg: #e8f5e8;
--card-bg: #f0faf0;
--input-bg: #dff0df;
--border: #b0d8b0;
--border-light: #80c080;
--text: #0a2a0a;
--text-muted: #2a6a2a;
--text-heading: #062006;
--btn-bg: #d0ebd0;
--btn-border: #4a8a4a;
--accent-green: #1a7a1a;
--accent-yellow: #4a8a00;
--accent-red: #cc2222;
--jog-hi: #d0ebd0;
--jog-lo: #bcdabc;
--jog-shadow: rgba(10,42,10,0.15);
--jog-inset: rgba(255,255,255,0.72);
--audio-level-bg: #d8edd8;
--audio-level-border: #80c080;
--audio-level-fill-start: #1a7a1a;
--audio-level-fill-end: #4a8a00;
--filter-bg: #d0ebd0;
--filter-fg: #0a2a0a;
--filter-border: #4a8a4a;
--wavelength-fg: #3a7a3a;
--spectrum-bg: #e0f0e0;
}
/* =========================================================================
Scheduler tab
========================================================================= */
.sch-panel {
padding: 1rem;
max-width: 900px;
}
.sch-toast {
position: fixed;
bottom: 1.5rem;
left: 50%;
transform: translateX(-50%);
padding: 0.5rem 1.25rem;
border-radius: 0.4rem;
color: #fff;
font-weight: 600;
font-size: 0.9rem;
z-index: 999;
pointer-events: none;
}
.sch-row {
display: flex;
flex-wrap: wrap;
gap: 1rem;
margin-bottom: 1rem;
align-items: flex-end;
}
.sch-label {
display: flex;
flex-direction: column;
gap: 0.3rem;
font-size: 0.85rem;
color: var(--text-muted);
font-weight: 600;
min-width: 9rem;
}
.sch-rig-select {
min-width: 10rem;
}
.sch-section {
margin-bottom: 1.5rem;
padding: 1rem;
background: var(--bg-secondary);
border-radius: 0.5rem;
border: 1px solid var(--border-light);
}
.sch-section-title {
font-size: 0.8rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--text-muted);
margin-bottom: 0.75rem;
}
.sch-ts-table {
width: 100%;
border-collapse: collapse;
font-size: 0.85rem;
margin-bottom: 1rem;
}
.sch-ts-table th,
.sch-ts-table td {
padding: 0.4rem 0.6rem;
text-align: left;
border-bottom: 1px solid var(--border-light);
}
.sch-ts-table th {
color: var(--text-muted);
font-weight: 600;
}
.sch-ts-table td:last-child {
white-space: nowrap;
}
.sch-ts-table td:last-child button {
font-size: 0.78rem;
padding: 0.18rem 0.45rem;
margin-right: 0.25rem;
}
.sch-ts-table td:last-child button:last-child {
margin-right: 0;
}
.sch-add-row {
align-items: flex-end;
}
.sch-actions {
display: flex;
gap: 0.75rem;
margin-bottom: 1.5rem;
}
/* Save is a primary action — accent background, inherits all other button rules. */
.sch-save-btn {
background: var(--accent-green);
color: #fff;
border-color: var(--accent-green);
font-weight: 700;
}
.sch-status-card {
font-size: 0.9rem;
color: var(--text-muted);
}
.sch-extra-bm-list {
display: flex;
flex-wrap: wrap;
gap: 4px;
min-height: 1.6rem;
}
.sch-extra-bm-tag {
display: inline-flex;
align-items: center;
gap: 3px;
background: var(--btn-bg);
border: 1px solid var(--border-light);
border-radius: 4px;
padding: 0.1rem 0.4rem;
font-size: 0.8rem;
color: var(--text-muted);
}
.sch-extra-bm-rm {
cursor: pointer;
opacity: 0.6;
font-size: 1rem;
line-height: 1;
}
.sch-extra-bm-rm:hover { opacity: 1; }
.bgd-toggle-wrap {
min-width: 18rem;
flex: 1 1 20rem;
}
.bgd-toggle-row {
display: inline-flex;
align-items: center;
gap: 0.55rem;
min-height: var(--control-height);
color: var(--text);
font-weight: 500;
}
.bgd-add-row {
display: flex;
gap: 0.55rem;
align-items: center;
width: 100%;
}
.bgd-bookmark-pick {
flex: 1 1 28rem;
min-width: 16rem;
}
.bgd-add-row .status-input {
flex: 1 1 auto;
}
.bgd-bookmark-list {
min-height: 1.8rem;
}
.bgd-bookmark-tag {
padding-right: 0.3rem;
}
.bgd-bookmark-meta {
color: var(--text-muted);
font-size: 0.78rem;
}
.bgd-status-list {
display: grid;
gap: 0.65rem;
}
.bgd-status-row {
display: flex;
justify-content: space-between;
gap: 1rem;
padding: 0.65rem 0.75rem;
border: 1px solid var(--border-light);
border-radius: 0.55rem;
background: color-mix(in srgb, var(--card-bg) 74%, transparent);
}
.bgd-status-name {
font-weight: 600;
}
.bgd-status-meta {
color: var(--text-muted);
font-size: 0.82rem;
}
.bgd-status-state {
align-self: center;
white-space: nowrap;
font-size: 0.78rem;
font-weight: 700;
letter-spacing: 0.05em;
text-transform: uppercase;
color: var(--accent-green);
}
.bgd-status-state[data-state="out_of_span"],
.bgd-status-state[data-state="waiting_for_spectrum"],
.bgd-status-state[data-state="waiting_for_user"],
.bgd-status-state[data-state="scheduler_has_control"],
.bgd-status-state[data-state="inactive"],
.bgd-status-state[data-state="handled_by_scheduler"],
.bgd-status-state[data-state="handled_by_virtual_channel"] {
color: var(--accent-yellow);
}
.bgd-status-state[data-state="missing_bookmark"],
.bgd-status-state[data-state="no_supported_decoders"] {
color: var(--accent-red);
}
@media (max-width: 600px) {
.channel-scheduler-controls {
flex-direction: column;
align-items: stretch;
}
.vchan-picker {
flex-basis: auto;
}
.scheduler-control-row {
align-items: stretch;
flex-basis: auto;
}
.scheduler-release-wrap {
align-items: stretch;
min-width: 0;
}
.scheduler-release-status {
text-align: left;
}
.sch-row {
flex-direction: column;
}
.sch-label {
min-width: 100%;
}
.bm-paginator {
flex-direction: column;
align-items: stretch;
}
.bm-page-controls {
justify-content: space-between;
}
.bm-page-controls button {
flex: 1 1 0;
min-width: 0;
}
.bm-page-indicator,
.bm-page-summary {
text-align: center;
}
.bgd-add-row,
.bgd-status-row {
flex-direction: column;
align-items: stretch;
}
.bgd-add-row button {
width: 100%;
}
}