.header{position:fixed;top:0;left:0;right:0;background:var(--color-header-footer-bg);color:var(--color-header-footer-text);display:flex;justify-content:space-between;align-items:center;padding:.4rem 1rem;height:var(--height-header);z-index:1000}.header a{color:var(--color-header-footer-text);text-decoration:none;margin:0 .3rem}.header a:hover{text-decoration:underline}.header-left{display:flex;align-items:center;gap:8px}.header-left img{height:20px}.header-right{display:flex;align-items:center;gap:8px}.icon-btn{background:none;border:none;cursor:pointer;padding:4px;border-radius:6px;color:inherit;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .1s}.icon-btn svg{width:16px;height:16px}.lang-group{display:flex;align-items:center;gap:0px}.footer{position:fixed;bottom:0;left:0;right:0;height:var(--height-footer);background:var(--color-header-footer-bg);color:var(--color-header-footer-text);display:flex;justify-content:center;align-items:center;font-size:.9rem;z-index:999}html,body,#root{margin:0;padding:0;min-height:100dvh;font-family:var(--font-base);background:var(--color-body-bg)}.login-content{display:grid;place-items:center;min-height:0;overflow:auto}.login-card{width:min(400px,90vw);border:1px solid #ddd;background:#fff;margin:100px auto;padding:24px;border-radius:8px}.login-card .input{display:block;width:100%;margin-top:4px;padding:8px}.login-card .btn{width:100%;padding:10px}.startBarContent{background:#003e99;color:#fff;border-radius:0 8px 8px 0;padding:1rem;width:var(--startBar-width);overflow:hidden;overflow-x:hidden;overflow-y:auto;transition:width var(--bars-transition-duration) var(--bars-transition-type)}.startBarContent nav{display:flex;flex-direction:column;gap:1rem}.startBarContent a{color:#fff;text-decoration:none;padding:.5rem;border-radius:4px;transition:background .3s}.startBarContent a:hover{background:#fff3}.startBarContent-toggle{display:block;width:100%;background:transparent;border:none;color:#fff;font-size:1rem;padding:.5rem;cursor:pointer;text-align:right;margin-bottom:.5rem}.startBarContent-toggle:hover{background:#ffffff26;border-radius:4px}.startBarContent-toggle.right{text-align:left}.endBarContent{background:#003e99;color:#fff;border-radius:8px 0 0 8px;padding:1rem;overflow-y:auto;overflow-x:hidden;width:var(--endBar-width);transition:width var(--bars-transition-duration) var(--bars-transition-type)}.endBarContent nav{display:flex;flex-direction:column;gap:1rem}.endBarContent a{color:#fff;text-decoration:none;padding:.5rem;border-radius:4px;transition:background .3s}.endBarContent a:hover{background:#fff3}.endBarContent-toggle{display:block;width:100%;background:transparent;border:none;color:#fff;font-size:1rem;padding:.5rem;cursor:pointer;text-align:left;margin-bottom:.5rem}.endBarContent-toggle:hover{background:#ffffff26;border-radius:4px}.submenu{position:absolute;top:100%;left:0;background:#0052cc;border:1px solid #ddd;display:flex;flex-direction:column;min-width:160px;z-index:100}.submenu a{padding:.5rem 1rem;white-space:nowrap}.submenu a:hover{background:#f5f5f5}.right-widget{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:80px}.date{font-size:.75rem;opacity:.7;text-transform:capitalize;letter-spacing:.03em}.time{font-size:1.1rem;font-weight:600;letter-spacing:.05em;color:inherit;font-variant-numeric:tabular-nums}.icon-row{display:flex;gap:6px}.context-menu{background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;min-width:160px;padding:4px 0}.context-menu-item{padding:8px 16px;cursor:pointer;font-size:14px}.context-menu-item:hover{background:#f5f5f5}.map-context-menu{position:fixed;z-index:1000;background:#fff;border:1px solid #ccc;border-radius:4px;padding:4px 0;list-style:none;margin:0;box-shadow:0 2px 8px #0003;min-width:180px}.map-context-menu li{padding:8px 16px;cursor:pointer;font-size:14px}.map-context-menu li:hover{background:#f0f0f0}dialog{border:none;border-radius:8px;padding:24px;min-width:400px;max-width:90vw;max-height:90vh;overflow-y:auto}dialog::backdrop{background:#0f172a8c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}dialog{border:none;border-radius:12px;padding:0;width:min(480px,90vw);box-shadow:0 4px 6px -1px #0000001a,0 20px 40px -8px #00000040;background:#fff;color:#1a1a2e;opacity:0;transform:translateY(-12px) scale(.98);transition:opacity .2s ease,transform .2s ease;position:fixed;top:50%;left:50%}dialog[open]{opacity:1;transform:translate(-50%,-50%)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #e8ecf0;cursor:grab;-webkit-user-select:none;user-select:none}.modal-header h2{font-size:1.1rem;font-weight:600;letter-spacing:-.01em}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:#6b7280;font-size:1.25rem;cursor:pointer;transition:background .15s,color .15s;line-height:1}.modal-close:hover{background:#f3f4f6;color:#1a1a2e}.modal-body{padding:20px 24px;line-height:1.6;color:#4b5563;font-size:.95rem}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px 20px;border-top:1px solid #e8ecf0}.modal-btn{padding:9px 18px;border-radius:8px;border:none;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s}.modal-btn:active{transform:scale(.97)}.modal-btn-secondary{background:#f3f4f6;color:#374151}.modal-btn-secondary:hover{background:#e5e7eb}.modal-btn-primary{background:#4f46e5;color:#fff;box-shadow:0 1px 3px #4f46e54d}.modal-btn-primary:hover{background:#4338ca;box-shadow:0 4px 12px #4f46e566}.zone-detail-dialog::backdrop{background:#0006}.zone-detail-dialog{border:none;border-radius:8px;padding:24px;min-width:300px;box-shadow:0 4px 16px #0000004d}:root,:host{--ol-background-color: white;--ol-accent-background-color: #F5F5F5;--ol-subtle-background-color: rgba(128, 128, 128, .25);--ol-partial-background-color: rgba(255, 255, 255, .75);--ol-foreground-color: #333333;--ol-subtle-foreground-color: #666666;--ol-brand-color: #00AAFF}.ol-box{box-sizing:border-box;border-radius:2px;border:1.5px solid var(--ol-background-color);background-color:var(--ol-partial-background-color)}.ol-mouse-position{top:8px;right:8px;position:absolute}.ol-scale-line{background:var(--ol-partial-background-color);border-radius:4px;bottom:8px;left:8px;padding:2px;position:absolute}.ol-scale-line-inner{border:1px solid var(--ol-subtle-foreground-color);border-top:none;color:var(--ol-foreground-color);font-size:10px;text-align:center;margin:1px;will-change:contents,width;transition:all .25s}.ol-scale-bar{position:absolute;bottom:8px;left:8px}.ol-scale-bar-inner{display:flex}.ol-scale-step-marker{width:1px;height:15px;background-color:var(--ol-foreground-color);float:right;z-index:10}.ol-scale-step-text{position:absolute;bottom:-5px;font-size:10px;z-index:11;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-text{position:absolute;font-size:12px;text-align:center;bottom:25px;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-singlebar{position:relative;height:10px;z-index:9;box-sizing:border-box;border:1px solid var(--ol-foreground-color)}.ol-scale-singlebar-even{background-color:var(--ol-subtle-foreground-color)}.ol-scale-singlebar-odd{background-color:var(--ol-background-color)}.ol-unsupported{display:none}.ol-viewport,.ol-unselectable{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.ol-viewport canvas{all:unset;overflow:hidden}.ol-viewport{touch-action:pan-x pan-y}.ol-selectable{-webkit-touch-callout:default;-webkit-user-select:text;-moz-user-select:text;user-select:text}.ol-grabbing{cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.ol-grab{cursor:move;cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.ol-control{position:absolute;background-color:var(--ol-subtle-background-color);border-radius:4px}.ol-zoom{top:.5em;left:.5em}.ol-rotate{top:.5em;right:.5em;transition:opacity .25s linear,visibility 0s linear}.ol-rotate.ol-hidden{opacity:0;visibility:hidden;transition:opacity .25s linear,visibility 0s linear .25s}.ol-zoom-extent{top:4.643em;left:.5em}.ol-full-screen{right:.5em;top:.5em}.ol-control button{display:block;margin:1px;padding:0;color:var(--ol-subtle-foreground-color);font-weight:700;text-decoration:none;font-size:inherit;text-align:center;height:1.375em;width:1.375em;line-height:.4em;background-color:var(--ol-background-color);border:none;border-radius:2px}.ol-control button::-moz-focus-inner{border:none;padding:0}.ol-zoom-extent button{line-height:1.4em}.ol-compass{display:block;font-weight:400;will-change:transform}.ol-touch .ol-control button{font-size:1.5em}.ol-touch .ol-zoom-extent{top:5.5em}.ol-control button:hover,.ol-control button:focus{text-decoration:none;outline:1px solid var(--ol-subtle-foreground-color);color:var(--ol-foreground-color)}.ol-zoom .ol-zoom-in{border-radius:2px 2px 0 0}.ol-zoom .ol-zoom-out{border-radius:0 0 2px 2px}.ol-attribution{text-align:right;bottom:.5em;right:.5em;max-width:calc(100% - 1.3em);display:flex;flex-flow:row-reverse;align-items:center}.ol-attribution a{color:var(--ol-subtle-foreground-color);text-decoration:none}.ol-attribution ul{margin:0;padding:1px .5em;color:var(--ol-foreground-color);text-shadow:0 0 2px var(--ol-background-color);font-size:12px}.ol-attribution li{display:inline;list-style:none}.ol-attribution li:not(:last-child):after{content:" "}.ol-attribution img{max-height:2em;max-width:inherit;vertical-align:middle}.ol-attribution button{flex-shrink:0}.ol-attribution.ol-collapsed ul{display:none}.ol-attribution:not(.ol-collapsed){background:var(--ol-partial-background-color)}.ol-attribution.ol-uncollapsible{bottom:0;right:0;border-radius:4px 0 0}.ol-attribution.ol-uncollapsible img{margin-top:-.2em;max-height:1.6em}.ol-attribution.ol-uncollapsible button{display:none}.ol-zoomslider{top:4.5em;left:.5em;height:200px}.ol-zoomslider button{position:relative;height:10px}.ol-touch .ol-zoomslider{top:5.5em}.ol-overviewmap{left:.5em;bottom:.5em}.ol-overviewmap.ol-uncollapsible{bottom:0;left:0;border-radius:0 4px 0 0}.ol-overviewmap .ol-overviewmap-map,.ol-overviewmap button{display:block}.ol-overviewmap .ol-overviewmap-map{border:1px solid var(--ol-subtle-foreground-color);height:150px;width:150px}.ol-overviewmap:not(.ol-collapsed) button{bottom:0;left:0;position:absolute}.ol-overviewmap.ol-collapsed .ol-overviewmap-map,.ol-overviewmap.ol-uncollapsible button{display:none}.ol-overviewmap:not(.ol-collapsed){background:var(--ol-subtle-background-color)}.ol-overviewmap-box{border:1.5px dotted var(--ol-subtle-foreground-color)}.ol-overviewmap .ol-overviewmap-box:hover{cursor:move}.ol-overviewmap .ol-viewport:hover{cursor:pointer}.ol-viewport.rtl .ol-top-left{left:unset;right:.5em}.ol-viewport.rtl .ol-top-right{right:unset;left:.5em}.ol-viewport.rtl .ol-bottom-left{left:unset;right:.5em}.ol-viewport.rtl .ol-bottom-right{right:unset;left:.5em}.ol-viewport.rtl .ol-scale-bar,.ol-viewport.rtl .ol-zoom{direction:rtl}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-Index:999999}.app-content{grid-area:content;position:relative;min-width:0;min-height:0;overflow:hidden;overflow-y:auto;padding:.5rem}.leaflet-wrapper{position:absolute;top:0;right:0;bottom:0;left:0}.grid{display:grid;height:100%;grid-template-columns:repeat(6,1fr);grid-auto-rows:minmax(150px,1fr);gap:.5rem;align-items:stretch}.grid>.card{min-height:0}.card{position:relative;height:100%;background:#fff;border-radius:8px;box-shadow:0 2px 5px #0000001a;text-align:center;font-weight:500;overflow:hidden}.card.span-1x1{grid-column:span 2}.card.span-half{grid-column:span 3}.card.span-2x1{grid-column:span 4}.card.span-3x1{grid-column:span 6}.card.span-1x2{grid-column:span 2;grid-row:span 2}.card.span-half-x2{grid-column:span 3;grid-row:span 2}.card.span-2x2{grid-column:span 4;grid-row:span 2}.card.span-3x2{grid-column:span 6;grid-row:span 2}.card.span-3x3{grid-column:span 6;grid-row:span 3}.card.span-3x6{grid-column:span 6;grid-row:span 6}.card.span-half-x3{grid-column:span 3;grid-row:span 3}.card.span-3x3 .leaflet-wrapper{position:relative;height:100%;width:100%}@media (max-width: 700px){.main{grid-template-columns:1fr}.right-panel,.left-panel{display:none}.grid{grid-template-columns:1fr}.card[class*=span-]{grid-column:span 1;grid-row:span 1}.card[class$=x2]{grid-row:span 2}.card[class$=x3]{grid-row:span 3}.card[class$=x4]{grid-row:span 4}}:root{--font-base: "Segoe UI", Roboto, sans-serif;--height-header: 40px;--height-footer: 40px;--top-topbar: var(--height-header);--height-topbar: 80px;--startBar-width: 160px;--endBar-width: 160px;--startBar-collapsed-width: 48px;--endBar-collapsed-width: 48px;--border-color: #0af;--bars-transition-duration: .2s;--bars-transition-type: ease}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;width:100%;height:100%;font-family:var(--font-base);background:var(--color-body-bg)}#root.app-layout{display:grid;height:100dvh;grid-template-columns:minmax(0,var(--startBar-width)) minmax(0,1fr) minmax(0,var(--endBar-width));grid-template-rows:calc(var(--height-header) + var(--height-topbar)) minmax(0,1fr) var(--height-footer);grid-template-areas:"topbar topbar topbar" "startBar content endBar" "footer footer footer";overflow:hidden;transition:grid-template-columns var(--bars-transition-duration) var(--bars-transition-type)}.topbar{grid-area:topbar;position:fixed;top:var(--top-topbar);left:0;right:0;height:80px;background:#0052cc;color:#fff;padding:0 1rem;display:flex;justify-content:space-between;align-items:center;z-index:999}.startBar{grid-area:startBar;border-inline-end:1px solid var(--border-color);overflow:auto;min-width:0;min-height:0;display:flex}.startBar.collapsed{width:var(--startBar-collapsed-width)}.endBar{grid-area:endBar;border-inline-start:1px solid var(--border-color);overflow:auto;min-width:0;min-height:0;display:flex}.endBar.collapsed{width:var(--endBar-collapsed-width)}.nav{display:flex;gap:1rem}.nav a{color:#fff;text-decoration:none;padding:.3rem .6rem;border-radius:4px;transition:background .3s}.nav a:hover{background:#fff3}@media (max-width: 900px){#root.app-layout{grid-template-columns:minmax(0,1fr);grid-template-areas:"topbar" "content" "footer"}.startBar,.endBar{display:none}}:root{--color-body-bg: #ffffff;--color-header-footer-bg: #0d1b2a;--color-text: #111111;--color-header-footer-text: #ffffff;--color-primary: #2563eb;--color-card: #f5f5f5}[data-theme=dark]{--color-body-bg: #ffffff;--color-header-footer-bg: #9aa0a7;--color-text: #111111;--color-header-footer-text: #0a0606;--color-primary: #60a5fa;--color-card: #1f2937}[data-theme=ocean]{--color-body-bg: #ffffff;--color-header-footer-bg: #0d1b2a;--color-text: #111111;--color-header-footer-text: #ffffff;--color-primary: #47b5ff;--color-card: #1363df}
