@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";@import "https://unpkg.com/leaflet@1.9.4/dist/leaflet.css";*,:before,:after{box-sizing:border-box}:root{--bg-main:#f8fafc;--bg-card:#fff;--bg-card-hover:#f1f5f9;--border-glow:#2563eb1a;--border-subtle:#e2e8f0;--color-leader:#1e3a8a;--color-relay:#047857;--color-explorer:#475569;--color-alert:#e11d48;--color-warning:#ea580c;--color-text-primary:#0f172a;--color-text-secondary:#475569;--color-text-muted:#94a3b8;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", monospace;--shadow-glow:0 4px 6px -1px #0000000d, 0 2px 4px -2px #0000000d;--shadow-card:0 10px 15px -3px #00000008, 0 4px 6px -4px #00000008;box-sizing:border-box}body{background-color:var(--bg-main);color:var(--color-text-primary);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;width:100vw;height:100vh;margin:0;padding:0;overflow:hidden}#root{flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.glass-panel{background:var(--bg-card);border:1px solid var(--border-subtle);box-shadow:var(--shadow-card);border-radius:10px;transition:all .2s ease-in-out}.glass-panel:hover{border-color:#cbd5e1;box-shadow:0 10px 20px -3px #0000000f}.dashboard-container{flex:1;gap:16px;width:100%;max-width:100%;height:calc(100vh - 70px);padding:16px;display:flex;overflow:hidden}.main-content{flex-direction:column;flex:1;gap:16px;height:100%;display:flex}.map-container{border:1px solid var(--border-subtle);box-shadow:var(--shadow-card);border-radius:10px;flex:1;position:relative;overflow:hidden}.sidebar{flex-direction:column;flex-shrink:0;gap:16px;width:360px;height:100%;display:flex}.dashboard-header{border-bottom:1px solid var(--border-subtle);background-color:#fff;justify-content:space-between;align-items:center;height:70px;padding:0 24px;display:flex;box-shadow:0 1px 2px #00000005}.header-title-container{align-items:center;gap:12px;display:flex}.header-logo{width:28px;height:28px;color:var(--color-leader)}.header-title-container h1{letter-spacing:.5px;text-transform:uppercase;color:var(--color-leader);margin:0;font-size:18px;font-weight:700}.header-title-container span{font-size:10px;font-family:var(--font-mono);color:var(--color-text-secondary);border:1px solid var(--border-subtle);text-transform:uppercase;background-color:#f1f5f9;border-radius:4px;padding:2px 6px;font-weight:500}.header-stats{font-family:var(--font-mono);gap:24px;font-size:12px;display:flex}.stat-item{flex-direction:column;align-items:flex-end;display:flex}.stat-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:9px}.stat-value{color:var(--color-text-primary);font-weight:600}.stat-value.ok{color:var(--color-relay)}.leaflet-container{font-family:var(--font-sans);background:#f1f5f9!important}.leaflet-tile{filter:none!important}.leaflet-bar{border:1px solid var(--border-subtle)!important;box-shadow:var(--shadow-glow)!important}.leaflet-bar a{color:var(--color-text-primary)!important;border-bottom:1px solid var(--border-subtle)!important;background-color:#fff!important}.leaflet-bar a:hover{background-color:#f8fafc!important}.leaflet-popup-content-wrapper{border:1px solid var(--border-subtle)!important;color:var(--color-text-primary)!important;background:#fff!important;border-radius:6px!important;box-shadow:0 10px 15px -3px #00000014!important}.leaflet-popup-tip{border:1px solid var(--border-subtle)!important;background:#fff!important}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.badge{text-transform:uppercase;font-size:9px;font-weight:600;font-family:var(--font-mono);border-radius:4px;padding:2px 6px}.badge-active{color:#1e40af;background:#dbeafe;border:1px solid #bfdbfe}.badge-relay{color:#065f46;background:#d1fae5;border:1px solid #a7f3d0}.badge-explorer{color:#334155;background:#f1f5f9;border:1px solid #e2e8f0}.badge-failure{color:#9f1239;background:#ffe4e6;border:1px solid #fecdd3}.btn-primary{color:#fff;font-weight:500;font-family:var(--font-sans);cursor:pointer;background:#2563eb;border:1px solid #1d4ed8;border-radius:6px;padding:8px 14px;transition:all .15s ease-in-out;box-shadow:0 1px 2px #0000000d}.btn-primary:hover{background:#1d4ed8;box-shadow:0 4px 6px -1px #2563eb33}.btn-secondary{border:1px solid var(--border-subtle);color:var(--color-text-secondary);cursor:pointer;background:#fff;border-radius:6px;padding:7px 12px;font-weight:500;transition:all .15s ease-in-out}.btn-secondary:hover{color:var(--color-text-primary);background:#f8fafc;border-color:#cbd5e1}.pulse-dot{background-color:var(--color-alert);border-radius:50%;width:6px;height:6px;animation:1.5s infinite pulse;display:inline-block}@keyframes pulse{0%{opacity:1;transform:scale(.9)}50%{opacity:.5;transform:scale(1.2)}to{opacity:1;transform:scale(.9)}}.map-drawing-active .leaflet-container,.map-drawing-active .leaflet-grab,.map-drawing-active .leaflet-interactive{cursor:crosshair!important}.leaflet-control-layers{border:1px solid var(--border-subtle)!important;font-family:var(--font-sans)!important;color:var(--color-text-primary)!important;background-color:#fff!important;border-radius:8px!important;padding:6px!important;box-shadow:0 4px 12px #00000014!important}.leaflet-control-layers-toggle{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%231e3a8a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polygon points='12 2 2 7 12 12 22 7 12 2'/><polyline points='2 17 12 22 22 17'/><polyline points='2 12 12 17 22 12'/></svg>")!important;background-position:50%!important;background-size:20px 20px!important;width:36px!important;height:36px!important}.leaflet-control-layers-list{padding:4px!important;font-size:11px!important;font-weight:600!important}.leaflet-control-layers-selector{accent-color:#1e3a8a!important;margin-right:6px!important}.map-container.route-active .leaflet-container,.map-container.route-active .leaflet-grab,.map-container.route-active .leaflet-interactive{cursor:crosshair!important}.map-container.reposition-active .leaflet-container,.map-container.reposition-active .leaflet-grab,.map-container.reposition-active .leaflet-interactive{cursor:move!important}.map-container.map-paused{transition:all .2s ease-in-out;border:1.5px solid #f59e0b!important;box-shadow:0 0 15px #f59e0b40!important}@keyframes chargePulse{0%{opacity:1}50%{opacity:.45}to{opacity:1}}@keyframes missionFlash{0%{border-color:var(--border-subtle);box-shadow:0 4px 16px #0000001a}15%{border-color:#ef4444;box-shadow:0 0 0 6px #ef444466,0 8px 30px #ef444499}30%{border-color:var(--border-subtle);box-shadow:0 4px 16px #0000001a}45%{border-color:#ef4444;box-shadow:0 0 0 6px #ef444466,0 8px 30px #ef444499}60%{border-color:var(--border-subtle);box-shadow:0 4px 16px #0000001a}75%{border-color:#ef4444;box-shadow:0 0 0 6px #ef444466,0 8px 30px #ef444499}to{border-color:var(--border-subtle);box-shadow:0 4px 16px #0000001a}}.mission-panel-flash{animation:1.8s ease-in-out missionFlash}body.shift-active,body.shift-active *{-webkit-user-select:none!important;user-select:none!important}.cursor-crosshair,.cursor-crosshair .leaflet-container,.cursor-crosshair .leaflet-grab,.cursor-crosshair .leaflet-interactive{cursor:crosshair!important}@keyframes pulse-temp-marker{0%{opacity:1;transform:scale(.6)}to{opacity:0;transform:scale(1.6)}}.pulse-temp-marker-ring{animation:1.4s ease-out infinite pulse-temp-marker}.minimal-aoo-popup .leaflet-popup-content-wrapper{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff!important;background:#0f172af2!important;border:1px solid #ffffff26!important;border-radius:4px!important;padding:0!important;box-shadow:0 4px 12px #00000026!important}.minimal-aoo-popup .leaflet-popup-content{text-transform:uppercase;letter-spacing:.5px;font-family:var(--font-sans)!important;margin:4px 8px!important;font-size:10px!important;font-weight:600!important}.minimal-aoo-popup .leaflet-popup-tip{background:#0f172af2!important;border:1px solid #ffffff26!important}@keyframes selectionPulse{0%{opacity:.9;transform:scale(.2)}to{opacity:0;transform:scale(2.8)}}.usv-selection-ring{border-radius:50%;width:48px;height:48px;position:absolute;top:0;left:0}.usv-selection-ring-container{background:0 0!important;border:none!important}.usv-selection-ring{pointer-events:none;box-sizing:border-box;border-radius:50%;width:48px;height:48px;animation:.45s cubic-bezier(.1,.8,.3,1) infinite selectionPulse;position:absolute;top:0;left:0}.custom-context-menu{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);z-index:5000;min-width:200px;font-family:var(--font-sans);pointer-events:auto;background:#fffffff5;border-radius:10px;padding:6px 0;animation:.15s cubic-bezier(.16,1,.3,1) contextFadeIn;position:absolute;box-shadow:0 12px 30px #0f172a26}@keyframes contextFadeIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.context-menu-header{color:var(--color-leader);border-bottom:1px solid var(--border-subtle);font-size:11px;font-weight:800;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;padding:6px 14px}.context-menu-item{color:var(--color-text-primary);cursor:pointer;justify-content:space-between;align-items:center;gap:8px;padding:8px 14px;font-size:11.5px;font-weight:550;transition:all .15s ease-in-out;display:flex;position:relative}.context-menu-item:hover{color:#1d4ed8;background-color:#1e3a8a0f}.context-menu-item.disabled{color:var(--color-text-muted);cursor:not-allowed;background-color:#0000!important}.context-menu-item.has-submenu:after{content:"→";color:var(--color-text-muted);font-size:11px;font-weight:700;transition:transform .15s ease-in-out}.context-menu-item.has-submenu:hover:after{color:#1d4ed8;transform:translate(2px)}.context-menu-submenu{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);z-index:5001;background:#fffffffa;border-radius:8px;min-width:170px;max-height:250px;padding:6px 0;animation:.12s cubic-bezier(.16,1,.3,1) contextFadeIn;display:none;position:absolute;top:-6px;left:99%;overflow-y:auto;box-shadow:0 10px 25px #0f172a1f}.context-menu-item:hover>.context-menu-submenu{display:block}.context-menu-separator{background-color:var(--border-subtle);height:1px;margin:4px 0}.context-menu-status-line{color:var(--color-text-secondary);font-size:10px;font-family:var(--font-mono);justify-content:space-between;gap:8px;padding:2px 14px;display:flex}.context-menu-status-label{color:var(--color-text-muted)}.context-menu-status-value{color:var(--color-text-primary);font-weight:600}.mission-creator-overlay{-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-subtle);z-index:6000;width:400px;max-width:90%;font-family:var(--font-sans);pointer-events:auto;background:#fffffffa;border-radius:14px;padding:20px;animation:.25s cubic-bezier(.16,1,.3,1) overlayPop;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 25px 60px -15px #0f172a4d}@keyframes overlayPop{0%{opacity:0;transform:translate(-50%,-46%)scale(.96)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.mission-creator-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:10px;display:flex}.mission-creator-title{color:var(--color-leader);text-transform:uppercase;letter-spacing:.8px;font-size:13.5px;font-weight:800;font-family:var(--font-mono);margin:0}.floating-draw-bar{z-index:4500;-webkit-backdrop-filter:blur(10px);color:var(--color-text-primary);background:#fffffff5;border:1.5px solid #ea580c;border-radius:20px;align-items:center;gap:12px;padding:8px 18px;font-size:11.5px;font-weight:600;display:flex;position:absolute;top:16px;left:50%;transform:translate(-50%);box-shadow:0 8px 25px #ea580c26}.landing-container{background-color:var(--bg-main);z-index:10000;width:100vw;height:100vh;font-family:var(--font-sans);color:var(--color-text-primary);justify-content:center;align-items:center;display:flex;position:fixed;top:0;left:0;overflow:hidden}.landing-grid-overlay{pointer-events:none;background-image:linear-gradient(#1e3a8a04 1px,#0000 1px),linear-gradient(90deg,#1e3a8a04 1px,#0000 1px);background-position:50%;background-size:40px 40px;width:100%;height:100%;position:absolute;top:0;left:0}.landing-glow-circles{pointer-events:none;filter:blur(40px);background:radial-gradient(circle,#2563eb0a 0%,#0000 70%);width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.landing-card{border:1px solid var(--border-subtle);width:420px;max-width:95%;box-shadow:var(--shadow-card), 0 20px 25px -5px #00000005;z-index:10;background:#fff;border-radius:12px;flex-direction:column;align-items:center;gap:24px;padding:40px;animation:.5s cubic-bezier(.16,1,.3,1) forwards landingFadeUp;display:flex}@keyframes landingFadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.landing-logo-container{flex-direction:column;align-items:center;gap:12px;display:flex}.landing-logo{object-fit:contain;width:auto;height:44px}.landing-subtitle{font-family:var(--font-mono);letter-spacing:1.5px;color:var(--color-text-muted);text-transform:uppercase;margin:0;font-size:10px;font-weight:700}.landing-description{color:var(--color-text-secondary);text-align:center;margin:0;font-size:12.5px;line-height:1.5}.landing-form{flex-direction:column;gap:16px;width:100%;display:flex}.landing-input-group{flex-direction:column;gap:6px;display:flex}.landing-label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:9.5px;font-weight:700;font-family:var(--font-mono)}.landing-input{border:1px solid var(--border-subtle);width:100%;color:var(--color-text-primary);font-size:13px;font-family:var(--font-sans);background:#fff;border-radius:6px;outline:none;padding:10px 12px;transition:all .15s ease-in-out}.landing-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.landing-input.error{border-color:var(--color-alert);box-shadow:0 0 0 3px #e11d481a}.landing-btn{color:#fff;cursor:pointer;background:#2563eb;border:1px solid #1d4ed8;border-radius:6px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px;font-size:13px;font-weight:600;transition:all .15s ease-in-out;display:flex;box-shadow:0 1px 2px #0000000d}.landing-btn:hover{background:#1d4ed8;box-shadow:0 4px 6px -1px #2563eb33}.landing-btn:active{transform:translateY(.5px)}.landing-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none!important;transform:none!important}.landing-error-message{color:var(--color-alert);align-items:center;gap:6px;font-size:11px;font-weight:500;animation:.4s ease-in-out landingShake;display:flex}@keyframes landingShake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.landing-footer{color:var(--color-text-muted);font-size:9px;font-family:var(--font-mono);letter-spacing:.5px}.leaflet-container,.leaflet-grab,.leaflet-interactive{cursor:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='1.5'><circle cx='12' cy='12' r='3'/><line x1='12' y1='2' x2='12' y2='8'/><line x1='12' y1='16' x2='12' y2='22'/><line x1='2' y1='12' x2='8' y2='12'/><line x1='16' y1='12' x2='22' y2='12'/></svg>") 12 12,crosshair!important}.leaflet-drag-target,.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-container,.leaflet-dragging .leaflet-interactive{cursor:grabbing!important}.leaflet-control,.leaflet-control *,.leaflet-popup-close-button,.leaflet-popup-close-button *{cursor:pointer!important}
