857 lines
33 KiB
CSS
857 lines
33 KiB
CSS
/* GPS Navigator — Touch-ready maritime UI */
|
|
/* ── AR Electronics brand tokens ───────────────────────────────────────────
|
|
ADDITIVOS — no reemplazan la paleta operacional existente.
|
|
Usar --brand-* solo para elementos de chrome UI (logo, topbar, pantallas
|
|
informativas). */
|
|
:root {
|
|
--brand-navy: #0D1B2A;
|
|
--brand-navy-mid: #1A2744;
|
|
--brand-blue-electric: #2563EB;
|
|
--brand-blue-neon: #4A9FE8;
|
|
--brand-blue-glow: #60B8FF;
|
|
--brand-text: #E2E8F0;
|
|
--brand-silver: #C8D2DC;
|
|
}
|
|
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;600&display=swap');
|
|
|
|
/* ══════════════════════════════════════════════════════════════════════════════
|
|
PALETAS DE COLOR
|
|
Todas las variables se sobreescriben por modo. Ningún elemento usa colores
|
|
hardcodeados (excepto los overlays del mapa, que siempre van oscuros).
|
|
color-mix() NO se usa — no existe en Chromium 87 (PyQt5 WebEngine).
|
|
══════════════════════════════════════════════════════════════════════════════ */
|
|
|
|
/* ── DAY — puente cubierto / nublado / pantalla interior ─────────────────── */
|
|
:root {
|
|
--bg: #0a1628;
|
|
--bg2: #0f2040;
|
|
--bg3: #152848;
|
|
--bg4: #1a3258;
|
|
--border: #1e3e6a;
|
|
--text: #cce4ff;
|
|
--muted: #4878a8;
|
|
--dim: #243a58;
|
|
--cyan: #00d8f0;
|
|
--cyan2: #0096b4;
|
|
--green: #2edc78;
|
|
--yellow: #f8cc38;
|
|
--red: #f46060;
|
|
--ok: #2edc78;
|
|
--warn: #f8cc38;
|
|
--err: #f46060;
|
|
/* glow para text-shadow: versión semitransparente del color primario */
|
|
--cyan-glow: rgba(0,216,240,0.32);
|
|
--ok-glow: rgba(46,220,120,0.40);
|
|
/* overlay del mapa — siempre oscuro para máximo contraste sobre tiles */
|
|
--overlay-bg: rgba(10,22,40,0.92);
|
|
--overlay-text: #a8c8e8;
|
|
/* modo-botón activo */
|
|
--modebtn-active-text: var(--text);
|
|
/* badge borders */
|
|
--badge-err-border: rgba(244,96,96,0.40);
|
|
--badge-ok-border: rgba(46,220,120,0.40);
|
|
--badge-fix-border: rgba(0,216,240,0.40);
|
|
/* layout */
|
|
--header-h: 56px;
|
|
--lp-w: 270px;
|
|
--rp-w: 280px;
|
|
--ol-filter: none;
|
|
--radius: 6px;
|
|
--touch: 48px;
|
|
}
|
|
|
|
/* ── DUSK — atardecer, conservar visión nocturna ─────────────────────────── */
|
|
html[data-mode="dusk"] {
|
|
--bg: #050910; --bg2: #080e1c; --bg3: #0c1424; --bg4: #101a2e;
|
|
--border: #162030; --text: #6080a0; --muted: #364e68; --dim: #1a2a3c;
|
|
--cyan: #2070a0; --cyan2: #185880;
|
|
--green: #186840; --yellow:#806010; --red: #883030;
|
|
--ok: #186840; --warn: #806010; --err: #883030;
|
|
--cyan-glow: rgba(32,112,160,0.28);
|
|
--ok-glow: rgba(24,104,64,0.30);
|
|
--overlay-bg: rgba(5,9,16,0.94);
|
|
--overlay-text: #506888;
|
|
--modebtn-active-text: #9ab8d0;
|
|
--badge-err-border: rgba(136,48,48,0.40);
|
|
--badge-ok-border: rgba(24,104,64,0.40);
|
|
--badge-fix-border: rgba(32,112,160,0.40);
|
|
--ol-filter: brightness(0.58) saturate(0.62);
|
|
}
|
|
|
|
/* ── NOCHE — visión nocturna, solo rojo tenue ────────────────────────────── */
|
|
html[data-mode="night"] {
|
|
--bg: #0a0000; --bg2: #120000; --bg3: #1a0202; --bg4: #220404;
|
|
--border: #320808; --text: #983020; --muted: #582010; --dim: #240808;
|
|
--cyan: #b83020; --cyan2: #882018;
|
|
--green: #802010; --yellow:#903010; --red: #c03030;
|
|
--ok: #802010; --warn: #903010; --err: #c03030;
|
|
--cyan-glow: rgba(184,48,32,0.28);
|
|
--ok-glow: rgba(128,32,16,0.28);
|
|
--overlay-bg: rgba(10,0,0,0.96);
|
|
--overlay-text: #602010;
|
|
--modebtn-active-text: #d08070;
|
|
--badge-err-border: rgba(192,48,48,0.40);
|
|
--badge-ok-border: rgba(128,32,16,0.40);
|
|
--badge-fix-border: rgba(184,48,32,0.40);
|
|
--ol-filter: brightness(0.26) saturate(0.12) sepia(0.95) hue-rotate(-22deg);
|
|
}
|
|
|
|
/* ── DAY+ — plena luz solar, máximo contraste ────────────────────────────── */
|
|
html[data-mode="dayplus"] {
|
|
--bg: #e8f2fc; /* blanco azulado claro */
|
|
--bg2: #ffffff; /* paneles blancos puros */
|
|
--bg3: #dae8f6; /* inputs */
|
|
--bg4: #c8d8ec; /* hover */
|
|
--border: #5080b0; /* azul medio — borde visible */
|
|
--text: #041220; /* casi negro */
|
|
--muted: #2050a0; /* azul oscuro legible */
|
|
--dim: #90aac8; /* separadores */
|
|
--cyan: #0050a0; /* azul profundo — readouts sobre blanco */
|
|
--cyan2: #003880; /* azul más oscuro */
|
|
--green: #006030; /* verde oscuro */
|
|
--yellow: #906000; /* ámbar oscuro */
|
|
--red: #c02020; /* rojo oscuro */
|
|
--ok: #006030;
|
|
--warn: #906000;
|
|
--err: #c02020;
|
|
--cyan-glow: transparent; /* no glow en modo claro */
|
|
--ok-glow: transparent;
|
|
--overlay-bg: rgba(4,18,32,0.90); /* mapa toolbar — siempre oscuro */
|
|
--overlay-text: #a0c0e0;
|
|
/* mode-btn activo: texto claro sobre fondo oscuro (--cyan2 = #003880) */
|
|
--modebtn-active-text: #e0eeff;
|
|
--badge-err-border: rgba(192,32,32,0.50);
|
|
--badge-ok-border: rgba(0,96,48,0.50);
|
|
--badge-fix-border: rgba(0,80,160,0.50);
|
|
--ol-filter: brightness(1.06) saturate(1.08);
|
|
}
|
|
|
|
|
|
/* ══════════════════════════════════════════════════════════════════════════════
|
|
RESET
|
|
══════════════════════════════════════════════════════════════════════════════ */
|
|
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
|
|
html, body {
|
|
height: 100%; overflow: hidden;
|
|
background: var(--bg); color: var(--text);
|
|
font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
|
|
font-size: 14px; -webkit-tap-highlight-color: transparent;
|
|
}
|
|
|
|
|
|
/* ══════════════════════════════════════════════════════════════════════════════
|
|
HEADER
|
|
══════════════════════════════════════════════════════════════════════════════ */
|
|
header {
|
|
height: var(--header-h);
|
|
background: var(--bg2);
|
|
border-bottom: 2px solid var(--border);
|
|
display: flex; align-items: center; gap: 16px; padding: 0 18px;
|
|
flex-shrink: 0; overflow: hidden;
|
|
}
|
|
|
|
/* Brand */
|
|
.brand {
|
|
display: flex; align-items: center; gap: 8px;
|
|
font-size: 1.05rem; font-weight: 800; letter-spacing: 2px;
|
|
color: var(--cyan); white-space: nowrap; flex-shrink: 0;
|
|
text-shadow: 0 0 16px var(--cyan-glow);
|
|
}
|
|
.brand-logo { height: 26px; width: auto; display: block; filter: drop-shadow(0 0 4px rgba(0,216,240,0.35)); }
|
|
.brand-name { display: flex; flex-direction: column; line-height: 1.1; }
|
|
.brand-sub { font-size: 0.58em; font-weight: 400; letter-spacing: 2px; color: var(--text); }
|
|
.brand span { color: var(--text); font-weight: 400; letter-spacing: 1px; }
|
|
|
|
/* GPS status: dot + port label, sin borde de chip */
|
|
.hdr-gps {
|
|
display: flex; align-items: center; gap: 5px; flex-shrink: 0;
|
|
}
|
|
.status-dot {
|
|
width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0;
|
|
background: var(--muted);
|
|
transition: background 0.3s, box-shadow 0.3s;
|
|
}
|
|
.status-dot.dot-ok {
|
|
background: var(--ok);
|
|
box-shadow: 0 0 6px var(--ok-glow), 0 0 14px var(--ok-glow);
|
|
}
|
|
.status-dot.dot-err { background: var(--err); }
|
|
.hdr-port {
|
|
font-size: 0.68rem; font-family: 'JetBrains Mono', monospace;
|
|
color: var(--muted); font-weight: 600; white-space: nowrap;
|
|
}
|
|
|
|
/* Fix badge — elemento independiente */
|
|
.fix-badge {
|
|
padding: 3px 8px; border-radius: 20px; flex-shrink: 0;
|
|
font-size: 0.62rem; font-weight: 700;
|
|
font-family: 'JetBrains Mono', monospace; letter-spacing: 0.5px;
|
|
white-space: nowrap;
|
|
}
|
|
.fix-none { background: rgba(220,80,80,0.16); color: var(--err); border: 1px solid var(--badge-err-border); }
|
|
.fix-ok { background: rgba(46,180,100,0.16); color: var(--ok); border: 1px solid var(--badge-ok-border); }
|
|
.fix-dgps { background: rgba(0,210,140,0.18); color: #00d28c; border: 1px solid rgba(0,210,140,0.45); } /* DGPS — verde esmeralda */
|
|
.fix-great { background: rgba(0,180,220,0.16); color: var(--cyan); border: 1px solid var(--badge-fix-border); }
|
|
|
|
/* Separador vertical para header */
|
|
.hdr-sep {
|
|
width: 1px; height: 22px; background: var(--border); flex-shrink: 0;
|
|
}
|
|
|
|
/* Botón PORT — círculo pequeño con ícono */
|
|
.port-btn {
|
|
width: 30px; height: 30px; flex-shrink: 0;
|
|
background: var(--bg3); border: 1px solid var(--border);
|
|
color: var(--muted); border-radius: 50%;
|
|
cursor: pointer; font-size: 0.8rem;
|
|
display: flex; align-items: center; justify-content: center;
|
|
transition: all 0.15s;
|
|
}
|
|
.port-btn:hover { border-color: var(--cyan); color: var(--cyan); }
|
|
.port-btn:active { background: var(--bg4); }
|
|
|
|
/* Mode selector — segmented control */
|
|
.mode-seg {
|
|
display: flex; flex-shrink: 0;
|
|
border: 1px solid var(--border);
|
|
border-radius: var(--radius);
|
|
overflow: hidden; background: var(--bg3);
|
|
}
|
|
.mode-btn {
|
|
height: 30px; padding: 0 10px;
|
|
background: transparent; border: none;
|
|
border-left: 1px solid var(--border);
|
|
color: var(--muted);
|
|
cursor: pointer; font-size: 0.62rem; font-weight: 700;
|
|
letter-spacing: 0.5px; white-space: nowrap;
|
|
transition: background 0.12s, color 0.12s;
|
|
}
|
|
.mode-btn:first-child { border-left: none; }
|
|
.mode-btn:hover { background: var(--bg4); color: var(--text); }
|
|
.mode-btn.active { background: var(--cyan2); color: var(--modebtn-active-text); }
|
|
|
|
/* UTC clock */
|
|
.utc-clock {
|
|
flex-shrink: 0;
|
|
font-family: 'JetBrains Mono', monospace;
|
|
font-size: 0.72rem; color: var(--muted); letter-spacing: 0.5px;
|
|
}
|
|
|
|
|
|
/* ══════════════════════════════════════════════════════════════════════════════
|
|
LAYOUT PRINCIPAL
|
|
══════════════════════════════════════════════════════════════════════════════ */
|
|
#app { display: flex; flex-direction: column; height: 100%; }
|
|
#main { flex: 1; display: flex; overflow: hidden; min-height: 0; }
|
|
|
|
|
|
/* ── Panel izquierdo (GPS readout + tabs) ────────────────────────────────── */
|
|
#left-panel {
|
|
width: var(--lp-w); min-width: var(--lp-w);
|
|
background: var(--bg2);
|
|
border-right: 1px solid var(--border);
|
|
display: flex; flex-direction: column;
|
|
overflow: hidden; /* el scroll va en .lp-content */
|
|
}
|
|
|
|
/* Tabs del panel izquierdo */
|
|
.lp-tabs {
|
|
display: flex; gap: 5px; padding: 8px 8px 0; flex-shrink: 0;
|
|
background: var(--bg2); border-bottom: 2px solid var(--border);
|
|
}
|
|
.lp-tab {
|
|
flex: 1; height: 44px;
|
|
background: var(--bg3); border: 1px solid var(--border);
|
|
color: var(--muted); border-radius: var(--radius) var(--radius) 0 0;
|
|
cursor: pointer; font-size: 0.62rem; font-weight: 700;
|
|
letter-spacing: 0.4px; transition: all 0.15s;
|
|
display: flex; align-items: center; justify-content: center; gap: 3px;
|
|
border-bottom: 2px solid transparent; position: relative; bottom: -2px;
|
|
}
|
|
.lp-tab:hover { color: var(--text); border-color: var(--cyan); border-bottom-color: transparent; }
|
|
.lp-tab:active { color: var(--text); border-color: var(--cyan); border-bottom-color: transparent; }
|
|
.lp-tab.active {
|
|
background: var(--bg2); border-color: var(--border);
|
|
border-bottom-color: var(--bg2); /* fusiona con el contenido */
|
|
color: var(--cyan); font-weight: 800;
|
|
}
|
|
|
|
/* Contenedor de cada tab */
|
|
.lp-content {
|
|
flex: 1; overflow-y: auto; padding: 10px;
|
|
display: flex; flex-direction: column; gap: 2px;
|
|
}
|
|
.lp-content.hidden { display: none; }
|
|
|
|
/* Toolbar dentro de los tabs WPT / RTE */
|
|
.lp-section-tools {
|
|
display: flex; gap: 6px; margin-bottom: 10px; flex-wrap: wrap;
|
|
}
|
|
.lp-section {
|
|
border-bottom: 1px solid var(--border);
|
|
padding-bottom: 10px; margin-bottom: 10px;
|
|
}
|
|
.lp-section:last-child { border-bottom: none; }
|
|
.lp-title {
|
|
font-size: 0.6rem; color: var(--muted);
|
|
text-transform: uppercase; letter-spacing: 1.5px;
|
|
margin-bottom: 7px; font-weight: 700;
|
|
}
|
|
/* Lectura grande (LAT / LON) */
|
|
.readout-big {
|
|
font-family: 'JetBrains Mono', monospace;
|
|
font-size: 1.15rem; color: var(--cyan);
|
|
font-weight: 600; line-height: 1.7;
|
|
text-shadow: 0 0 10px var(--cyan-glow);
|
|
}
|
|
.lp-row { display: flex; gap: 6px; }
|
|
.lp-field { flex: 1; min-width: 0; }
|
|
.lp-lbl {
|
|
font-size: 0.6rem; color: var(--muted);
|
|
text-transform: uppercase; letter-spacing: 0.8px; margin-bottom: 2px;
|
|
}
|
|
.lp-val {
|
|
font-family: 'JetBrains Mono', monospace;
|
|
font-size: 0.95rem; color: var(--text); font-weight: 600;
|
|
}
|
|
|
|
|
|
/* ── Mapa central ────────────────────────────────────────────────────────── */
|
|
#map-wrap { flex: 1; position: relative; min-width: 0; }
|
|
/* IMPORTANTE: NO aplicar filter directamente a #map — en Qt5 WebEngine el filter crea
|
|
un compositing layer que desplaza las coordenadas de los eventos de puntero (bug Chromium 83).
|
|
El modo nocturno se maneja por: opacidad del layer OSM (via GPSMap.setOsmOpacity) +
|
|
paleta S-52 de colores (via ChartLayer.setChartMode) + color de fondo del canvas. */
|
|
#map { width: 100%; height: 100%; background: #a8c8e8; /* ocean blue — visible sin tiles OSM */ }
|
|
|
|
/* Barra de coordenadas (always dark overlay sobre el mapa) */
|
|
#map-coords {
|
|
position: absolute; bottom: 6px; left: 50%; transform: translateX(-50%);
|
|
z-index: 10;
|
|
background: var(--overlay-bg);
|
|
color: var(--overlay-text);
|
|
font-family: 'JetBrains Mono', monospace;
|
|
font-size: 0.68rem; padding: 3px 10px; border-radius: 10px;
|
|
pointer-events: none;
|
|
border: 1px solid rgba(255,255,255,0.10);
|
|
backdrop-filter: blur(4px);
|
|
}
|
|
|
|
/* ── Map Tools panel (fondo del left panel) ──────────────────────────────── */
|
|
#lp-maptools {
|
|
flex-shrink: 0;
|
|
border-top: 2px solid var(--border);
|
|
background: var(--bg2);
|
|
padding: 8px;
|
|
}
|
|
.mt-label {
|
|
font-size: 0.58rem; font-weight: 700; letter-spacing: 1.5px;
|
|
color: var(--muted); text-transform: uppercase;
|
|
margin-bottom: 6px;
|
|
}
|
|
.mt-grid {
|
|
display: grid;
|
|
grid-template-columns: repeat(3, 1fr);
|
|
gap: 4px;
|
|
}
|
|
.mt-btn {
|
|
height: 36px;
|
|
background: var(--bg3); border: 1px solid var(--border);
|
|
color: var(--text); border-radius: var(--radius);
|
|
cursor: pointer; font-size: 0.68rem; font-weight: 700;
|
|
letter-spacing: 0.3px; transition: all 0.12s;
|
|
display: flex; align-items: center; justify-content: center;
|
|
}
|
|
.mt-btn:hover { border-color: var(--cyan); color: var(--cyan); background: var(--bg4); }
|
|
.mt-btn:active { background: var(--bg4); }
|
|
.mt-btn.active {
|
|
background: var(--cyan); color: var(--bg); border-color: var(--cyan);
|
|
}
|
|
/* Draw modes activos → amarillo */
|
|
.mt-btn.active#btn-draw-wpt,
|
|
.mt-btn.active#btn-draw-route {
|
|
background: var(--yellow); color: #0a1628; border-color: var(--yellow);
|
|
}
|
|
|
|
/* Chart name indicator sobre el mapa (bottom-right) */
|
|
#map-chart-info {
|
|
position: absolute; bottom: 32px; right: 8px; z-index: 10;
|
|
background: var(--overlay-bg);
|
|
color: var(--cyan);
|
|
font-family: 'JetBrains Mono', monospace;
|
|
font-size: 0.65rem; padding: 2px 8px; border-radius: 8px;
|
|
pointer-events: none;
|
|
border: 1px solid rgba(0,216,240,0.25);
|
|
opacity: 0; transition: opacity 0.2s;
|
|
white-space: nowrap;
|
|
}
|
|
#map-chart-info.visible { opacity: 1; }
|
|
|
|
/* Compatibilidad: .tb-btn se mantiene para no romper nada */
|
|
.tb-btn {
|
|
height: var(--touch); min-width: var(--touch);
|
|
background: var(--bg3); border: 1px solid var(--border);
|
|
color: var(--text); border-radius: var(--radius);
|
|
cursor: pointer; font-size: 0.72rem; font-weight: 700;
|
|
transition: all 0.15s;
|
|
display: flex; align-items: center; justify-content: center; padding: 0 10px;
|
|
}
|
|
.tb-btn:hover { border-color: var(--cyan); color: var(--cyan); }
|
|
.tb-btn.active { background: var(--cyan); color: var(--bg); border-color: var(--cyan); }
|
|
|
|
|
|
/* ── Panel derecho (satélites) ───────────────────────────────────────────── */
|
|
#right-panel {
|
|
width: var(--rp-w); min-width: var(--rp-w);
|
|
background: var(--bg2); border-left: 1px solid var(--border);
|
|
padding: 10px 8px; overflow-y: auto;
|
|
display: flex; flex-direction: column; align-items: center; gap: 6px;
|
|
}
|
|
.rp-title {
|
|
font-size: 0.6rem; color: var(--muted);
|
|
text-transform: uppercase; letter-spacing: 1.5px;
|
|
align-self: flex-start; font-weight: 700;
|
|
}
|
|
/* ── Canvas wrappers para overlay de labels HTML ─────────────────────────── */
|
|
.canvas-wrap {
|
|
position: relative;
|
|
display: block;
|
|
line-height: 0; /* evita espacio extra bajo el canvas */
|
|
}
|
|
.canvas-labels {
|
|
position: absolute;
|
|
top: 0; left: 0; right: 0; bottom: 0;
|
|
pointer-events: none;
|
|
overflow: hidden;
|
|
}
|
|
.canvas-labels span {
|
|
position: absolute;
|
|
font-family: 'JetBrains Mono', monospace;
|
|
font-size: 9px;
|
|
line-height: 1;
|
|
white-space: nowrap;
|
|
-webkit-font-smoothing: antialiased;
|
|
}
|
|
|
|
#sky-canvas {
|
|
border-radius: 50%; border: 1px solid var(--border);
|
|
display: block;
|
|
}
|
|
.rp-sat-count {
|
|
font-size: 0.68rem; color: var(--muted);
|
|
font-family: 'JetBrains Mono', monospace;
|
|
}
|
|
#sat-used { color: var(--ok); font-weight: 700; }
|
|
#sat-view { color: var(--cyan); }
|
|
|
|
|
|
/* ── Sección NAV activo (GO-TO waypoint) ─────────────────────────────────── */
|
|
#nav-section .lp-val { color: var(--warn); }
|
|
.small-btn {
|
|
height: 36px; padding: 0 14px;
|
|
background: var(--bg3); border: 1px solid var(--border);
|
|
color: var(--text); border-radius: var(--radius);
|
|
cursor: pointer; font-size: 0.72rem; font-weight: 600;
|
|
transition: all 0.15s; white-space: nowrap;
|
|
display: inline-flex; align-items: center;
|
|
}
|
|
.small-btn:hover, .small-btn:active {
|
|
border-color: var(--cyan); color: var(--cyan); background: var(--bg4);
|
|
}
|
|
|
|
|
|
/* ══════════════════════════════════════════════════════════════════════════════
|
|
NMEA LOG
|
|
══════════════════════════════════════════════════════════════════════════════ */
|
|
.nmea-log {
|
|
font-family: 'JetBrains Mono', monospace; font-size: 0.72rem;
|
|
line-height: 1.6; white-space: pre-wrap; color: var(--muted);
|
|
flex: 1; overflow-y: auto;
|
|
}
|
|
|
|
|
|
/* ══════════════════════════════════════════════════════════════════════════════
|
|
LISTAS (Waypoints / Routes)
|
|
══════════════════════════════════════════════════════════════════════════════ */
|
|
.hidden { display: none !important; }
|
|
.empty-list { color: var(--muted); font-size: 0.75rem; padding: 16px 4px; }
|
|
.item-list { display: flex; flex-direction: column; gap: 6px; }
|
|
.list-item {
|
|
background: var(--bg3); border: 1px solid var(--border);
|
|
border-radius: var(--radius); padding: 10px 12px;
|
|
transition: border-color 0.15s;
|
|
}
|
|
.list-item:hover { border-color: var(--dim); }
|
|
.list-item.item-active { border-color: var(--warn); }
|
|
.item-name { font-weight: 700; font-size: 0.88rem; color: var(--text); }
|
|
.item-sub {
|
|
font-family: 'JetBrains Mono', monospace;
|
|
font-size: 0.72rem; color: var(--muted); margin-top: 3px;
|
|
}
|
|
.item-nav {
|
|
font-family: 'JetBrains Mono', monospace;
|
|
font-size: 0.75rem; color: var(--cyan); margin-top: 3px;
|
|
}
|
|
.item-btns { display: flex; gap: 6px; margin-top: 8px; }
|
|
.icon-btn {
|
|
height: 34px; min-width: 34px; padding: 0 8px;
|
|
background: var(--bg); border: 1px solid var(--border);
|
|
color: var(--text); border-radius: var(--radius);
|
|
cursor: pointer; font-size: 0.78rem;
|
|
display: inline-flex; align-items: center; justify-content: center;
|
|
transition: all 0.15s;
|
|
}
|
|
.icon-btn:hover, .icon-btn:active { border-color: var(--cyan); color: var(--cyan); }
|
|
.icon-btn.icon-del:hover, .icon-btn.icon-del:active { border-color: var(--err); color: var(--err); }
|
|
|
|
|
|
/* ══════════════════════════════════════════════════════════════════════════════
|
|
MODALES (Waypoint / Route / PORT / ENC charts)
|
|
══════════════════════════════════════════════════════════════════════════════ */
|
|
.modal-overlay {
|
|
position: fixed; top: 0; right: 0; bottom: 0; left: 0;
|
|
background: rgba(0,0,0,0.72);
|
|
display: flex; align-items: center; justify-content: center;
|
|
z-index: 300;
|
|
}
|
|
.modal {
|
|
background: var(--bg2); border: 1px solid var(--border);
|
|
border-radius: 10px; min-width: 320px; max-width: 440px; width: 95%;
|
|
box-shadow: 0 16px 48px rgba(0,0,0,0.65);
|
|
}
|
|
.modal-header {
|
|
display: flex; justify-content: space-between; align-items: center;
|
|
padding: 0 16px; height: 50px;
|
|
border-bottom: 1px solid var(--border);
|
|
font-weight: 700; font-size: 0.8rem; letter-spacing: 1px;
|
|
color: var(--cyan); background: var(--bg3);
|
|
border-radius: 10px 10px 0 0;
|
|
}
|
|
.modal-close {
|
|
width: 38px; height: 38px;
|
|
background: none; border: none; color: var(--muted);
|
|
cursor: pointer; font-size: 1.1rem;
|
|
display: flex; align-items: center; justify-content: center;
|
|
border-radius: var(--radius); transition: all 0.15s;
|
|
}
|
|
.modal-close:hover, .modal-close:active { color: var(--err); background: rgba(200,60,60,0.12); }
|
|
.modal-body { padding: 16px; }
|
|
.modal-btns { display: flex; gap: 8px; margin-top: 16px; flex-wrap: wrap; }
|
|
|
|
/* Campos de formulario */
|
|
.form-field { margin-bottom: 12px; }
|
|
.form-lbl {
|
|
display: block; font-size: 0.62rem; color: var(--muted);
|
|
text-transform: uppercase; letter-spacing: 1px;
|
|
margin-bottom: 5px; font-weight: 600;
|
|
}
|
|
.form-inp, .form-sel {
|
|
width: 100%; height: var(--touch);
|
|
background: var(--bg3); border: 1px solid var(--border);
|
|
color: var(--text); padding: 9px 10px;
|
|
border-radius: var(--radius); font-size: 0.82rem; font-family: inherit;
|
|
transition: border-color 0.15s;
|
|
}
|
|
.form-inp:focus, .form-sel:focus { outline: none; border-color: var(--cyan); }
|
|
|
|
/* Botones de acción */
|
|
.btn-primary {
|
|
height: var(--touch); padding: 0 20px;
|
|
background: var(--cyan); border: none; color: var(--bg);
|
|
border-radius: var(--radius); cursor: pointer;
|
|
font-weight: 700; font-size: 0.78rem; letter-spacing: 0.5px;
|
|
transition: opacity 0.15s;
|
|
display: inline-flex; align-items: center;
|
|
}
|
|
/* DAY+: --bg = #e8f2fc (claro) sobre --cyan = #0050a0 (oscuro) → OK */
|
|
.btn-primary:hover, .btn-primary:active { opacity: 0.85; }
|
|
.btn-primary:disabled { opacity: 0.4; cursor: not-allowed; }
|
|
|
|
.btn-secondary {
|
|
height: var(--touch); padding: 0 18px;
|
|
background: var(--bg3); border: 1px solid var(--border); color: var(--text);
|
|
border-radius: var(--radius); cursor: pointer; font-size: 0.78rem;
|
|
transition: all 0.15s;
|
|
display: inline-flex; align-items: center;
|
|
}
|
|
.btn-secondary:hover, .btn-secondary:active { border-color: var(--cyan); color: var(--cyan); }
|
|
|
|
/* Selector de waypoints para rutas */
|
|
.wpt-selector {
|
|
max-height: 160px; overflow-y: auto;
|
|
border: 1px solid var(--border); border-radius: var(--radius); padding: 4px;
|
|
}
|
|
.rte-wpt-row {
|
|
display: flex; align-items: center; gap: 8px;
|
|
padding: 8px 6px; cursor: pointer; border-radius: 4px; min-height: 40px;
|
|
}
|
|
.rte-wpt-row:hover, .rte-wpt-row:active { background: var(--bg4); }
|
|
.rte-wpt-sub {
|
|
color: var(--muted); font-size: 0.65rem;
|
|
font-family: 'JetBrains Mono', monospace; margin-left: auto;
|
|
}
|
|
|
|
/* Modal de cartas más ancho */
|
|
#modal-charts { max-width: 500px; }
|
|
|
|
/* ── ENC layers modal (AVANZADO) ─────────────────────────────────────────── */
|
|
#modal-enc-layers { max-width: 340px; }
|
|
.el-section-hdr {
|
|
font-size: 0.62rem; font-weight: 700; letter-spacing: 0.06em;
|
|
color: var(--cyan); text-transform: uppercase;
|
|
padding: 8px 4px 3px; margin-top: 4px;
|
|
border-top: 1px solid var(--bg4);
|
|
}
|
|
.el-section-hdr:first-child { border-top: none; margin-top: 0; }
|
|
.enc-layer-group {
|
|
display: flex; flex-direction: column; gap: 6px;
|
|
padding: 4px 0;
|
|
}
|
|
.enc-layer-lbl {
|
|
display: flex; align-items: flex-start; gap: 10px;
|
|
padding: 8px 10px; border-radius: 5px; cursor: pointer;
|
|
border: 1px solid var(--border);
|
|
background: var(--bg3);
|
|
transition: background 0.15s;
|
|
-webkit-user-select: none; user-select: none;
|
|
}
|
|
.enc-layer-lbl:hover { background: var(--bg4); }
|
|
.enc-layer-lbl input[type="checkbox"] {
|
|
margin-top: 2px; accent-color: var(--cyan); flex-shrink: 0;
|
|
width: 15px; height: 15px; cursor: pointer;
|
|
}
|
|
.enc-layer-lbl > div { display: flex; flex-direction: column; flex: 1; }
|
|
.enc-layer-lbl .el-name {
|
|
font-size: 0.76rem; font-weight: 600; color: var(--text);
|
|
line-height: 1.3; display: block;
|
|
}
|
|
.enc-layer-lbl .el-desc {
|
|
font-size: 0.63rem; color: var(--muted); margin-top: 1px; line-height: 1.3; display: block;
|
|
}
|
|
|
|
/* ── Boat Center button ──────────────────────────────────────────────────── */
|
|
.mt-boat-center {
|
|
width: 100%;
|
|
height: 40px;
|
|
background: var(--cyan2);
|
|
border-color: var(--cyan);
|
|
color: var(--text);
|
|
font-size: 0.72rem;
|
|
font-weight: 800;
|
|
letter-spacing: 1px;
|
|
}
|
|
.mt-boat-center:hover {
|
|
background: var(--cyan);
|
|
color: var(--bg);
|
|
border-color: var(--cyan);
|
|
}
|
|
|
|
/* ── Zoom controls sobre el mapa ────────────────────────────────────────── */
|
|
#map-zoom-ctrl {
|
|
position: absolute;
|
|
right: 12px;
|
|
top: 12px;
|
|
z-index: 10;
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 3px;
|
|
z-index: 100;
|
|
}
|
|
.map-zoom-btn {
|
|
width: 40px;
|
|
height: 40px;
|
|
background: var(--overlay-bg);
|
|
border: 1px solid rgba(255,255,255,0.18);
|
|
color: var(--overlay-text);
|
|
border-radius: var(--radius);
|
|
cursor: pointer;
|
|
font-size: 1.35rem;
|
|
font-weight: 700;
|
|
line-height: 1;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
transition: background 0.15s, color 0.15s;
|
|
backdrop-filter: blur(4px);
|
|
-webkit-backdrop-filter: blur(4px);
|
|
}
|
|
.map-zoom-btn:hover { background: rgba(0,216,240,0.28); color: #00d8f0; border-color: rgba(0,216,240,0.50); }
|
|
.map-zoom-btn:active { background: rgba(0,216,240,0.45); }
|
|
|
|
/* ── ENC detail level selector ──────────────────────────────────────────── */
|
|
.enc-level-sel {
|
|
display: flex;
|
|
gap: 3px;
|
|
margin-top: 3px;
|
|
}
|
|
.enc-lvl {
|
|
flex: 1;
|
|
padding: 5px 2px;
|
|
font-size: 0.60rem;
|
|
font-weight: 700;
|
|
letter-spacing: 0.5px;
|
|
text-transform: uppercase;
|
|
background: var(--bg3);
|
|
color: var(--muted);
|
|
border: 1px solid var(--border);
|
|
border-radius: var(--radius);
|
|
cursor: pointer;
|
|
transition: background 0.15s, color 0.15s, border-color 0.15s;
|
|
}
|
|
.enc-lvl:hover { background: var(--bg4); color: var(--text); border-color: var(--cyan2); }
|
|
.enc-lvl.active { background: var(--cyan2); color: #fff; border-color: var(--cyan); font-weight: 800; }
|
|
|
|
/* ── ENC hover tooltip ──────────────────────────────────────────────────────
|
|
Aparece flotante sobre el mapa al pasar el ratón por una ayuda a la navegación.
|
|
Diseño ECDIS: fondo oscuro, borde cyan, tipografía compacta.
|
|
──────────────────────────────────────────────────────────────────────────── */
|
|
.enc-tooltip {
|
|
position: absolute;
|
|
z-index: 200;
|
|
pointer-events: none; /* no bloquea el ratón */
|
|
background: rgba(6, 14, 28, 0.96);
|
|
border: 1px solid #00b8d0;
|
|
border-radius: 4px;
|
|
padding: 6px 10px;
|
|
min-width: 110px;
|
|
max-width: 230px;
|
|
box-shadow: 0 4px 16px rgba(0,0,0,0.80);
|
|
}
|
|
.enc-tt-type {
|
|
font-size: 0.62rem;
|
|
font-weight: 700;
|
|
letter-spacing: 0.6px;
|
|
text-transform: uppercase;
|
|
color: #00c8e8;
|
|
margin-bottom: 2px;
|
|
}
|
|
.enc-tt-name {
|
|
font-size: 0.72rem;
|
|
font-weight: 600;
|
|
color: #deeeff;
|
|
line-height: 1.3;
|
|
}
|
|
.enc-tt-light {
|
|
font-size: 0.66rem;
|
|
color: #cc88ff;
|
|
font-family: 'JetBrains Mono', monospace;
|
|
margin-top: 2px;
|
|
}
|
|
.enc-tt-cat {
|
|
font-size: 0.63rem;
|
|
color: #7898b8;
|
|
margin-top: 1px;
|
|
}
|
|
|
|
/* ── Feature info panel (panel derecho, aparece al click) ───────────────────
|
|
ECDIS-style: fila etiqueta/valor compacta, badge de color por tipo de ayuda.
|
|
──────────────────────────────────────────────────────────────────────────── */
|
|
#rp-feat-info {
|
|
margin: 8px 0 0 0;
|
|
border-top: 1px solid var(--border);
|
|
padding: 7px 0 0 0;
|
|
font-size: 0.82rem;
|
|
}
|
|
.fi-header {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 6px;
|
|
margin-bottom: 6px;
|
|
}
|
|
.fi-badge {
|
|
font-size: 1.0rem;
|
|
flex-shrink: 0;
|
|
line-height: 1;
|
|
}
|
|
.fi-type {
|
|
font-size: 0.80rem;
|
|
font-weight: 700;
|
|
letter-spacing: 0.4px;
|
|
text-transform: uppercase;
|
|
color: var(--cyan);
|
|
flex: 1;
|
|
white-space: nowrap;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
}
|
|
.fi-close {
|
|
background: none;
|
|
border: none;
|
|
color: var(--muted);
|
|
cursor: pointer;
|
|
font-size: 1.0rem;
|
|
padding: 0 2px;
|
|
flex-shrink: 0;
|
|
line-height: 1;
|
|
}
|
|
.fi-close:hover { color: var(--text); }
|
|
.fi-rows { display: table; width: 100%; border-collapse: collapse; }
|
|
.fi-row { display: table-row; }
|
|
.fi-lbl {
|
|
display: table-cell;
|
|
color: var(--muted);
|
|
padding: 2px 8px 2px 0;
|
|
white-space: nowrap;
|
|
vertical-align: top;
|
|
width: 62px;
|
|
font-size: 0.75rem;
|
|
}
|
|
.fi-val {
|
|
display: table-cell;
|
|
color: var(--text);
|
|
vertical-align: top;
|
|
font-size: 0.82rem;
|
|
word-break: break-word;
|
|
}
|
|
.fi-row.fi-light .fi-val {
|
|
color: #cc88ff;
|
|
font-family: 'JetBrains Mono', monospace;
|
|
font-size: 0.76rem;
|
|
}
|
|
.fi-empty {
|
|
font-size: 0.76rem;
|
|
color: var(--muted);
|
|
font-style: italic;
|
|
padding: 2px 0;
|
|
}
|
|
|
|
/* ── MARCA modal — selector de tipo de marca ────────────────────────────────── */
|
|
.marca-grid {
|
|
display: grid;
|
|
grid-template-columns: repeat(4, 1fr);
|
|
gap: 8px;
|
|
margin: 12px 0;
|
|
}
|
|
.marca-item {
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
gap: 4px;
|
|
padding: 10px 6px 8px;
|
|
border: 1px solid var(--border);
|
|
border-radius: var(--radius);
|
|
cursor: pointer;
|
|
background: var(--bg2);
|
|
transition: border-color 0.15s, background 0.15s;
|
|
}
|
|
.marca-item:hover { border-color: var(--cyan); background: var(--bg3); }
|
|
.marca-item.selected { border-color: var(--cyan); background: var(--bg4); }
|
|
.marca-icon { font-size: 1.6rem; line-height: 1; }
|
|
.marca-label { font-size: 0.60rem; color: var(--muted); text-align: center; line-height: 1.2; }
|
|
|
|
/* ── Lock button ─────────────────────────────────────────────────────────── */
|
|
.icon-btn.icon-lock {
|
|
color: var(--muted);
|
|
font-size: 0.80rem;
|
|
}
|
|
.icon-btn.icon-lock.locked {
|
|
color: var(--yellow);
|
|
}
|
|
.list-item.item-locked {
|
|
opacity: 0.75;
|
|
border-left: 2px solid var(--yellow);
|
|
}
|
|
/* ── Mark list item ──────────────────────────────────────────────────────── */
|
|
.mark-item-icon { font-size: 1.1rem; line-height: 1; flex-shrink: 0; }
|
|
.mark-item-body { flex: 1; min-width: 0; }
|