@import"https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@100..900&display=swap";:root{font-family:Noto Sans KR,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;color:#fff;background-color:#2b2b2f;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease}[data-theme=light]{color:#1a1a1a;background-color:#f2f2f2}*{box-sizing:border-box;margin:0;padding:0;font-family:Noto Sans KR,sans-serif}body{margin:0;padding:0;background-color:#2b2b2f;color:#fff;min-height:100vh;transition:background-color .3s ease,color .3s ease}#root{width:100%;height:100vh}button{border-radius:4px;border:1px solid transparent;padding:.4em .8em;font-size:.9em;font-weight:500;font-family:inherit;cursor:pointer;transition:all .25s}button:focus,button:focus-visible{outline:2px solid #646cff}*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.6) rgba(43,43,47,.8)}[data-theme=light] *{scrollbar-color:rgba(0,0,0,.3) rgba(242,242,242,.8)}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-button{display:none}*::-webkit-scrollbar-track{background:#2b2b2fcc;border-radius:4px}[data-theme=light] *::-webkit-scrollbar-track{background:#f2f2f2cc}*::-webkit-scrollbar-thumb{background:#4a90e299;border-radius:4px;border:1px solid rgba(43,43,47,.8)}[data-theme=light] *::-webkit-scrollbar-thumb{background:#4a90e266;border:1px solid rgba(242,242,242,.8)}*::-webkit-scrollbar-thumb:hover{background:#4a90e2cc}[data-theme=light] *::-webkit-scrollbar-thumb:hover{background:#4a90e299}*::-webkit-scrollbar-thumb:active{background:#4a90e2}[data-theme=light] *::-webkit-scrollbar-thumb:active{background:#4a90e2cc}*::-webkit-scrollbar-corner{background:#2b2b2fcc}[data-theme=light] *::-webkit-scrollbar-corner{background:#f2f2f2cc}:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: hsl(6, 78%, 57%);--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-container-width: fit-content;--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-padding: 14px;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-toast-shadow: 0px 4px 12px rgba(0, 0, 0, .1);--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;width:var(--toastify-container-width);box-sizing:border-box;color:#fff;display:flex;flex-direction:column}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y: 0;position:relative;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;display:flex;flex:1 auto;align-items:center;word-break:break-word}@media only screen and (max-width:480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width: 100%;margin-bottom:0;border-radius:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{margin-inline-end:10px;width:22px;flex-shrink:0;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;position:absolute;top:6px;right:6px;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:1;opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{position:absolute;overflow:hidden;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.header-container{display:flex;flex-direction:column;height:80px;background:var(--static-bg-1)}.header-bottom{display:flex;background:var(--bg-L3);color:var(--text-primary);height:30px;position:relative;align-items:center;justify-content:space-between;padding:0 10px}.header-region{flex:1;color:var(--text-primary);font-size:14px;margin-left:10px}.header-bottom-subtabs{position:absolute;display:flex;gap:4px;align-items:center;height:100%;z-index:3}.header-bottom-subtab-item{padding:4px 12px;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .2s;white-space:nowrap}.header-bottom-subtab-item:hover{background-color:var(--bg-hover);color:var(--text-primary)}.header-bottom-subtab-item.active{background-color:var(--bg-L6);color:var(--text-primary);font-weight:600}.notifications-container{display:flex;align-items:center;margin-right:15px}.header{display:flex;justify-content:space-between;align-items:center;padding:0 10px;background-color:var(--static-bg-1);border-bottom:1px solid var(--static-border-color);height:50px}.header-left{display:flex;flex:25;gap:10px}.header-center{flex:50;display:flex;justify-content:center}.header-right{color:var(--static-text-secondary);display:flex;flex:25;flex-direction:row;justify-content:space-evenly;align-items:center;gap:4px;margin:0 10px}.home-btn{cursor:pointer;display:flex;align-items:center;justify-content:center;width:80px;gap:8px}.home-btn:hover{background-color:var(--static-bg-4)}.nav-tabs{display:flex;width:100%;position:relative}.nav-tab-wrapper{flex:1;position:relative}.nav-tab{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background-color:var(--static-bg-1);color:var(--static-text-secondary);padding:8px;font-size:18px;font-weight:700;cursor:pointer;transition:all .2s}.nav-tab:hover{background-color:var(--static-bg-4);color:var(--static-text-primary)}.nav-tab.active{background-color:var(--static-bg-3);color:var(--static-text-primary)}.subtab-dropdown{position:absolute;top:100%;left:0;right:0;background-color:var(--static-bg-2);border:1px solid #555;border-top:none;box-shadow:0 4px 8px #0000004d;z-index:12;overflow:hidden}.subtab-item{display:block;width:100%;text-align:left;background-color:transparent;color:var(--static-text-tertiary);border:none;padding:10px 16px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;border-bottom:1px solid #444}.subtab-item:last-child{border-bottom:none}.subtab-item:hover{background-color:#3a3a3a;color:var(--static-text-primary);padding-left:20px}.user-info{padding:2px 0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:14px}.user-name{font-weight:600;color:var(--static-text-primary)}.current-time{color:var(--static-text-tertiary)}.user-menu-container{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;position:relative}.icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center;height:100%;padding:0 8px}.icon-wrapper:hover{cursor:pointer;background-color:var(--static-bg-4)}.settings-subtab-dropdown{position:absolute;top:100%;right:0;background-color:var(--static-bg-1);border:1px solid #555;box-shadow:0 4px 8px #0000004d;z-index:12;min-width:150px;overflow:hidden}.settings-subtab-item{display:block;width:100%;text-align:left;background-color:transparent;color:var(--static-text-secondary);border:none;padding:10px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border-bottom:1px solid #444}.settings-subtab-item:last-child{border-bottom:none}.settings-subtab-item:hover{background-color:var(--static-bg-2);color:var(--static-text-primary);padding-left:20px}.weather-info{display:flex;align-items:center;gap:8px;font-size:12px}.temperature,.wind-speed,.rainfall{background-color:var(--color-success);color:var(--static-text-primary);padding:0 8px;border-radius:4px;font-weight:600}.datetime-info{font-size:12px;color:var(--static-text-tertiary);text-align:right}.header .favorite-star{color:#ffc107;font-size:1.2rem}.app{min-height:100vh;background-color:#2b2b2f;color:#fff;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;display:flex;flex-direction:column;transition:background-color .3s ease,color .3s ease}[data-theme=light] .app{background-color:#f2f2f2;color:#1a1a1a}.main-content{position:relative;height:calc(100vh - 80px);flex:1}.back-button{transition:all .3s ease}.back-button:hover{background-color:#357abd!important;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}body{margin:0;padding:0;background-color:#2b2b2f;color:#fff;transition:background-color .3s ease,color .3s ease}[data-theme=light] body{background-color:#f2f2f2;color:#1a1a1a}.Toastify__toast{width:auto!important;min-width:240px!important;max-width:1000px!important;color:var(--text-primary);background-color:var(--bg-L1);justify-content:center}:root{--color-primary: #4a90e2;--color-primary-hover: #357abd;--color-success: #28a745;--color-warning: #ffc107;--color-danger: #dc3545;--color-caution: #fd7e14;--color-info: #6c757d;--bg-L1: #000;--bg-L2: #161619;--bg-L3: #2B2B2F;--bg-L4: #3A3A3F;--bg-L5: #4A4A4F;--bg-L6: #5C5C62;--bg-L7: #707077;--bg-white-15: rgba(255, 255, 255, .15);--bg-popup-background: rgba(0, 0, 0, .6);--bg-popup-highlight: rgba(188, 188, 255, .05);--bg-hover: var(--bg-L7);--border-soft: #3F3F46;--border-medium: #52525B;--border-strong: #71717A;--text-primary: #FFFFFF;--text-secondary: #E0E0E0;--text-tertiary: #B0B0B0;--text-muted: #808080;--text-filled-btn: #FFF;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--grid-columns: repeat(96, 1fr);--grid-rows: repeat(48, 1fr);--grid-gap: var(--spacing-xs);--grid-padding: var(--spacing-sm);--grid-bg-color: var(--bg-L3);--grid-section-bg: var(--bg-L4);--grid-border-color: var(--border-soft);--static-bg-1: #2B2B2F;--static-bg-2: #3A3A3F;--static-bg-3: #4A4A4F;--static-bg-4: #4C5054;--static-bg-5: #5C5C62;--static-bg-6: #838383;--static-text-primary: #FFF;--static-text-secondary: #E0E0E0;--static-text-tertiary: #B0B0B0;--static-text-muted: #888;--static-border-color: rgba(68, 68, 68, .6)}[data-theme=light]{--bg-L1: #FFFFFF;--bg-L2: #F9F9F9;--bg-L3: #F2F2F2;--bg-L4: #EAEAEA;--bg-L5: #E4E4E4;--bg-L6: #DCDCDC;--bg-L7: #D0D0D0;--bg-white-15: rgba(0, 0, 0, .15);--bg-popup-background: var(--bg-L1);--bg-popup-highlight: rgba(188, 188, 255, .05);--bg-hover: var(--bg-L7);--border-soft: #D4D4D8;--border-medium: #A1A1AA;--border-strong: #71717A;--text-primary: #000;--text-secondary: #3A3A3F;--text-tertiary: #5C5C62;--text-muted: #808080}.flex-col{display:flex;flex-direction:column}.flex-row{display:flex;flex-direction:row}.h100{height:100%}.w100{width:100%}.cursor-pointer{cursor:pointer}.flex-center{justify-content:center;align-items:center}.flex-end{align-items:center;justify-content:flex-end}.alert{display:flex;text-align:center;justify-content:center;align-items:center;border-radius:var(--radius-md);color:#fff;border:0;max-height:20px;min-width:20px;padding:2px}button:focus,button:focus-visible{outline:none!important}.cesium-viewer-bottom{display:none!important}.over-scroll{overflow:scroll}.scroll-clipper{overflow-y:scroll;padding:var(--spacing-sm)}.pagination-container{display:flex;justify-content:center;align-items:center;margin-top:var(--spacing-md)}.pagination{display:flex;gap:5px}.page-btn{padding:var(--spacing-sm) var(--spacing-md);border:1px solid #ddd;background:#fff;cursor:pointer;border-radius:var(--radius-sm);font-size:.9rem;transition:none}.page-btn-num{flex:1 1}.page-btn:hover:not(:disabled){background-color:#f8f9fa}.page-btn.active{background-color:#007bff;color:var(--text-filled-btn);border-color:#007bff}.page-btn:disabled{opacity:.5;cursor:not-allowed}.tab-content{color:var(--text-tertiary);font-size:16px;padding:var(--spacing-xl);background:var(--bg-L3);border-radius:var(--radius-sm);min-height:300px}.analytics-main-content{grid-column:4 / 97;grid-row:1 / 49;border:1px solid var(--border-soft);display:flex;flex-direction:column;overflow:hidden}.analytics-content-area{flex:1;overflow-y:auto;padding:var(--spacing-xl)}.page-title{color:var(--text-primary);font-size:24px;font-weight:700;margin-bottom:var(--spacing-xl);padding-bottom:10px;border-bottom:2px solid var(--border-soft)}.favorite-star{color:var(--color-warning);cursor:pointer;transition:color .2s ease}.favorite-star.favorited,.favorite-star:hover{color:var(--color-warning)}.save-button{padding:6px var(--spacing-lg);background-color:var(--color-primary);color:var(--text-filled-btn);border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;transition:background-color .2s}.save-button:hover{background-color:var(--color-primary-hover)}.placeholder-text{color:var(--text-muted);font-size:16px;line-height:1.6}.section-title{display:flex;justify-content:space-between;align-items:center;font-weight:600;color:var(--text-primary);padding-bottom:var(--spacing-xs)}.section-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-medium)}.info-form{display:flex;flex-direction:column;gap:6px}.info-form-row{display:flex;gap:var(--spacing-sm);align-items:center}.info-form-label{background-color:var(--static-bg-4);border:1px solid var(--border-soft);border-radius:var(--radius-sm);padding:var(--spacing-xs) 10px;font-size:14px;color:var(--static-text-primary);font-weight:600;text-align:center;flex:1}.info-form-value{background-color:var(--bg-L3);border:1px solid var(--border-soft);border-radius:var(--radius-sm);padding:var(--spacing-xs) 10px;font-size:14px;color:var(--text-primary);text-align:center;flex:2}.table-header{display:grid;grid-template-columns:2fr 1fr 1fr .5fr;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:rgb(from var(--bg-L4) r g b / .3);border-radius:var(--radius-sm);font-size:12px;font-weight:600;color:var(--text-primary);border:1px solid var(--border-soft)}.table-row{display:grid;grid-template-columns:2fr 1fr 1fr .5fr;gap:var(--spacing-sm);align-items:center;padding:5px 6px;border-bottom:1px solid var(--border-soft)}.table-row:hover{background-color:var(--bg-hover);cursor:pointer}.common-table-container{flex:1;overflow:auto}.common-table{width:100%;border-collapse:collapse;font-size:13px;color:var(--text-primary)}.common-table thead{background-color:var(--bg-popup-highlight);position:sticky;top:0;z-index:10}.common-table th{padding:10px var(--spacing-sm);text-align:left;font-weight:600;border-bottom:2px solid var(--border-soft);white-space:nowrap;color:var(--text-primary);font-size:12px}.common-table tbody tr{border-bottom:1px solid var(--border-soft);transition:background-color .2s ease;will-change:background-color}.common-table tbody tr:hover{background-color:var(--bg-hover)}.common-table td{padding:var(--spacing-sm);color:var(--text-primary);font-size:13px;border-right:none}.common-table.text-center th,.common-table.text-center td{text-align:center}.common-table.no-data{text-align:center;padding:40px;color:var(--text-muted);font-size:14px}.common-table tbody tr.selected{background-color:#ffc10733;border-left:3px solid var(--color-warning)}.common-table tbody tr.selected:hover{background-color:var(--bg-hover)}.common-table tbody tr.selected td{color:var(--text-primary);font-weight:500}.marker-controls{position:absolute;bottom:20px;left:20px;display:flex;gap:var(--spacing-sm);z-index:12}.marker-control-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);background:var(--bg-L1);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;padding:var(--spacing-sm) var(--spacing-xs);text-wrap:nowrap;font-weight:700;color:var(--text-primary)}.marker-control-btn:hover{background:var(--bg-L5)}.marker-control-btn.active{opacity:1}.marker-control-icon{width:28px;height:28px;object-fit:contain}.marker-control-btn span{font-size:11px;font-weight:500;text-align:center}.MuiSelect-select{background-color:var(--bg-L1)!important;color:var(--text-primary)!important;padding:10px 14px}.MuiSelect-icon{color:var(--text-primary)!important}.mui-common-select-menu{background-color:var(--bg-L3)!important;color:var(--text-tertiary)!important;border:1px solid var(--border-soft)!important}.mui-common-select-menu .MuiMenuItem-root{color:var(--text-tertiary)!important}.mui-common-select-menu .MuiMenuItem-root:hover{background-color:#4a90e21a!important}.mui-common-select-menu .MuiMenuItem-root.Mui-selected{background-color:#4a90e233!important;color:var(--color-primary)!important}.mui-common-select-menu .MuiMenuItem-root.Mui-selected:hover{background-color:#4a90e24d!important}input.date-input,.date-input{padding:var(--spacing-xs) var(--spacing-sm);color:var(--text-primary);background-color:var(--bg-L3);border:1px solid var(--border-soft);max-width:300px!important;border-radius:var(--radius-sm);font-size:14px}.date-input::placeholder{color:var(--text-muted)}.date-input:hover{border-color:var(--border-medium)}.date-input:focus{border-color:var(--color-primary);outline:none}.map-general-search{position:absolute;top:12px;right:62px;z-index:1000;display:flex;flex-direction:column;align-items:stretch;gap:var(--spacing-xs);max-width:min(320px,calc(100vw - 120px))}.map-general-search-bar{display:flex;align-items:center;gap:var(--spacing-xs);background:var(--bg-popup-background);border:1px solid var(--border-medium);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-sm);min-height:40px;box-sizing:border-box}.map-general-search-input{flex:1;min-width:0;background:transparent;border:none;color:var(--text-primary);font-size:14px;padding:var(--spacing-xs)}.map-general-search-input::placeholder{color:var(--text-muted)}.map-general-search-input:focus{outline:none}.map-general-search-submit{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xs);background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:background .15s ease,color .15s ease}.map-general-search-submit:hover{background:var(--bg-L4);color:var(--color-primary)}.map-general-search-icon{font-size:22px!important}.map-general-search-results{background:var(--bg-popup-background);border:1px solid var(--border-medium);border-radius:var(--radius-md);box-shadow:0 2px 12px #00000026;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.map-general-search-results-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border-soft);font-size:13px;font-weight:600;color:var(--text-primary)}.map-general-search-count{color:var(--color-primary);font-size:12px}.map-general-search-results-list{overflow-y:auto;padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-xs)}.map-general-search-empty{padding:var(--spacing-md);text-align:center;color:var(--text-tertiary);font-size:13px}.map-general-result-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-sm);border:1px solid var(--border-soft);transition:background .15s ease,border-color .15s ease;background:var(--bg-popup-background)}.map-general-result-row:hover{border-color:var(--color-primary)}.map-general-result-main{flex:1;min-width:0}.map-general-result-name{font-weight:600;font-size:14px;color:var(--text-primary)}.map-general-result-address{font-size:12px;color:var(--text-tertiary);margin-top:2px}.map-compass{position:absolute;top:12px;right:12px;width:40px;height:40px;z-index:1000;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--bg-L3);transition:transform .15s ease,box-shadow .15s ease}.map-compass:hover{background:var(--bg-L5)}.map-compass-indicator{width:24px;height:28px;position:relative;display:flex;align-items:center;justify-content:center}.map-compass-triangle{position:absolute;left:50%;transform:translate(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent}.map-compass-triangle-north{top:0;border-bottom:14px solid #ff0e00}.map-compass-triangle-south{bottom:0;border-top:14px solid #0061ff}.map-scale-bar{position:absolute;bottom:12px;right:12px;z-index:1000;display:flex;flex-direction:column;align-items:flex-end;gap:2px;background:#00000080;padding:6px 10px;border-radius:var(--radius-sm);box-shadow:0 1px 4px #0000004d}.map-scale-bar-line{height:4px;background:#fff;border:1px solid rgba(255,255,255,.5);border-radius:2px;min-width:40px}.map-scale-bar-label{font-size:11px;color:#fffffff2;font-weight:500}.map-distance-measure-toggle.MuiToggleButton-root{position:absolute;bottom:56px;right:12px;z-index:1000;padding:6px;background:var(--bg-L2)!important;color:var(--text-primary)!important;border:1px solid var(--border-medium)!important}.map-distance-measure-toggle.MuiToggleButton-root.Mui-selected{background:#00bcd4!important;color:var(--text-primary)!important}.map-wms-test-toggle.MuiToggleButton-root{position:absolute;bottom:100px;right:12px;z-index:1000;padding:6px;background:var(--bg-L2)!important;color:var(--text-primary)!important;border:1px solid var(--border-medium)!important}.map-wms-test-toggle.MuiToggleButton-root.Mui-selected{background:#00bcd4!important;color:var(--text-primary)!important}.map-distance-measure-tooltip{position:absolute;z-index:1001;pointer-events:none;max-width:280px;padding:6px 10px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;line-height:1.35;color:var(--text-primary);background:var(--bg-L2);box-shadow:0 2px 8px #00000059;white-space:nowrap}.map-distance-measure-start-label{position:absolute;z-index:1000;pointer-events:none;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:11px;font-weight:600;line-height:1.3;color:#fffffffa;background:#006450d1;border:1px solid rgba(100,255,200,.4);box-shadow:0 1px 6px #00000059;white-space:nowrap}.map-distance-measure-start-label--done{background:#003c32e0}.map-distance-measure-result-label{position:absolute;z-index:1001;pointer-events:none;padding:6px 10px;border-radius:var(--radius-sm);font-size:12px;font-weight:600;line-height:1.35;color:#e0f7fa;background:#001e28d9;border:1px solid rgba(0,229,255,.45);box-shadow:0 2px 10px #0006;white-space:nowrap}.map-area{position:absolute;inset:0;display:flex;flex-direction:column;background-color:var(--bg-L3);z-index:1}.map-area .panel-remote-cluster,.map-area .panel-remote,.map-area .marker-controls{z-index:15;visibility:visible;pointer-events:auto}.map-container{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:var(--bg-L5);margin:0;border-radius:0;border:none;z-index:1;height:100%;width:100%}#cesium-container{width:100%!important;height:100%!important;border:none;border-radius:0}.map-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--color-info);text-align:center}.map-placeholder .placeholder-text{font-size:24px;font-weight:600;margin-bottom:8px}.placeholder-subtitle{font-size:14px;color:var(--text-muted)}.section-popup{width:440px;max-height:85vh;display:flex;flex-direction:column;background-color:var(--bg-popup-background);border:1px solid rgb(from var(--border-soft) r g b / .5);border-radius:8px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 20px #0000004d;overflow:hidden;-webkit-user-select:none;user-select:none;animation:sectionPopupSlideIn .3s ease-out}.section-popup.section-popup--closing{animation:sectionPopupSlideOut .3s ease-in-out forwards}@keyframes sectionPopupSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes sectionPopupSlideOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-20px) scale(.95)}}.section-popup--dragging{cursor:grabbing;box-shadow:0 12px 40px #0006}.section-popup-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;border-bottom:1px solid var(--border-soft);cursor:grab}.section-popup-header:active{cursor:grabbing}.section-popup-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.section-popup-favorite-star{color:#ccc}.section-popup-favorite-star.section-popup-favorite-star--favorited,.section-popup-favorite-star:hover{color:var(--color-warning)}.section-popup-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;display:flex;align-items:center;justify-content:center}.section-popup-close:hover{color:var(--text-primary)}.section-popup-body{padding:10px 12px;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;color:var(--text-primary)}.section-popup-resize-handle{flex:0 0 auto;height:8px;min-height:8px;cursor:ns-resize;touch-action:none;border-top:1px solid var(--border-soft);background:linear-gradient(to bottom,transparent 0,transparent 2px,rgb(from var(--border-soft) r g b / .35) 2px,rgb(from var(--border-soft) r g b / .35) 3px,transparent 3px);background-size:24px 3px;background-position:center 3px;background-repeat:no-repeat}.section-popup-resize-handle:hover{background-color:rgb(from var(--color-primary) r g b / .08)}.section-popup--resizing{-webkit-user-select:none;user-select:none}.section-popup--resizing .section-popup-body{pointer-events:none}.section-popup-address{font-size:14px;color:var(--text-tertiary);margin-bottom:10px;line-height:1.4}.section-popup-status{display:flex;gap:12px;margin-bottom:10px}.section-popup-status-item{display:flex;align-items:center;gap:8px}.section-popup-status-label{font-size:14px;color:var(--text-primary);font-weight:500}.section-popup-menu{display:flex;flex-direction:column;gap:4px}.section-popup-menu-item{background:none;border:none;padding:6px 8px;text-align:left;font-size:16px;color:var(--text-primary);cursor:pointer;border-radius:6px;transition:all .2s ease;font-weight:500}.section-popup-menu-item:hover{background-color:var(--bg-hover);color:var(--color-primary)}.section-popup-menu-item.section-popup-menu-item--active{background-color:#e3f2fd;color:#1976d2;font-weight:600}.section-popup-menu-item.section-popup-menu-item--active:hover{background-color:var(--bg-hover)}.section-popup-menu-item.section-popup-menu-item--disabled{opacity:.5;cursor:not-allowed;pointer-events:none;background:var(--bg-L6)}.panel-remote-cluster{position:absolute;top:62px;right:12px;z-index:15;display:flex;flex-direction:row;align-items:flex-start;justify-content:flex-end;gap:var(--spacing-sm);visibility:visible;pointer-events:none}.panel-remote-cluster>.detail-search-slideout,.panel-remote-cluster>.panel-remote{pointer-events:auto}.detail-search-slideout{position:absolute;right:100%;margin-right:var(--spacing-sm);top:0;max-width:720px;max-height:calc(100vh - 96px);overflow-y:auto;overflow-x:hidden;border-radius:var(--radius-md);background:var(--bg-popup-background);box-shadow:0 2px 12px #00000038;transform:translate(calc(100% + var(--spacing-sm)));transition:transform .25s ease-out;z-index:14}.detail-search-slideout--open{transform:translate(0)}.detail-search-slideout:not(.detail-search-slideout--open){pointer-events:none}.panel-remote{position:absolute;inset:62px 12px auto auto;width:fit-content;display:flex;flex-direction:column;gap:6px;z-index:15;visibility:visible;pointer-events:auto;overflow:visible}.panel-remote-cluster .panel-remote{position:relative;inset:auto}.panel-remote-section{display:flex;flex-direction:column;gap:6px;align-items:stretch}.panel-remote-list{display:flex;flex-direction:column;gap:6px}.panel-remote-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:40px;height:40px;padding:0;font-size:12px;font-weight:500;color:var(--text-primary);background:var(--bg-L3);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.panel-remote-btn:hover{opacity:1;background:var(--bg-L2)}.panel-remote-btn.active{opacity:1;background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.panel-remote-marker-wrap{position:relative}.panel-remote-marker-trigger{width:100%}.panel-remote-marker-flyout{position:absolute;right:100%;top:50%;transform:translateY(-50%);margin-right:10px;padding:8px;background:var(--bg-L3);box-shadow:0 2px 12px #0000002e;border-radius:var(--radius-md);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .15s ease,visibility .15s ease;z-index:20}.panel-remote-marker-flyout:not(.panel-remote-marker-flyout--open),.panel-remote-marker-flyout:not(.panel-remote-marker-flyout--open) *{pointer-events:none}.panel-remote-marker-flyout--open{opacity:1;visibility:visible;pointer-events:auto}.panel-remote-marker-flyout--open *{pointer-events:auto}.panel-remote-marker-flyout:before{content:"";position:absolute;right:-8px;top:50%;transform:translateY(-50%);width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-left:8px solid #fff;filter:drop-shadow(1px 0 0 rgba(0,0,0,.06))}.panel-remote-marker-flyout .marker-controls{position:static;left:auto;bottom:auto;display:flex;flex-direction:column;gap:6px;z-index:auto}.panel-remote-marker-flyout .marker-control-btn{flex-direction:row;width:auto;min-width:140px;height:auto;min-height:44px;padding:8px 10px;justify-content:flex-start;opacity:.65}.panel-remote-marker-flyout .marker-control-btn:hover{transform:none;opacity:.9}.panel-remote-marker-flyout .marker-control-btn.active{opacity:1}.search-container{min-width:425px;display:flex;align-items:center;height:100%;width:100%;padding:0 10px}.input-and-logo{display:flex;align-items:center;width:100%;height:100%;gap:10px;position:relative}.logo-container{flex:1;color:var(--static-text-primary);font-weight:700;cursor:pointer;transition:opacity .3s ease,max-width .3s ease;min-width:0;overflow:hidden;max-width:100%}.logo-container.hidden{max-width:0;flex:0;margin:0;padding:0;overflow:hidden}.search-bar{display:flex;align-items:center;background-color:var(--static-bg-3);border-radius:6px;padding:var(--spacing-xs) var(--spacing-sm);min-height:40px;gap:8px;width:40px;transition:all .3s ease;flex-shrink:0;position:absolute;right:0;top:50%;transform:translateY(-50%);justify-content:flex-end;cursor:pointer}.search-bar:hover{background-color:var(--static-bg-6)}.search-bar.expanded{width:100%}.search-input{background:transparent;border:none;color:var(--static-text-primary);padding:6px 8px;font-size:14px;width:100%}.search-input::placeholder{color:var(--static-text-muted)}.search-input:focus{outline:none}.search-icon{background:none;border:none;color:var(--static-text-secondary)}.detail-search-btn{background-color:var(--static-bg-4);color:var(--static-text-primary);border:1px solid #666;padding:6px;font-size:10px;border-radius:4px}.detail-search-btn:hover{background-color:#5a5a5a}.search-panel{width:300px}.search-panel-content{display:flex;flex-direction:column;height:100%}.search-categories{scrollbar-gutter:stable;flex:7;overflow-y:auto}.search-category{background:none!important;color:var(--text-primary)!important;margin:0!important;border-bottom:1px solid var(--border-strong)!important;box-shadow:none!important;padding:0 8px!important;overflow:hidden}.category-header{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;color:var(--static-text-primary);font-size:13px;font-weight:600;cursor:pointer}.category-header svg{color:var(--color-primary);font-size:18px!important}.category-header span{color:var(--text-primary)}.category-content{padding:8px 10px!important;display:flex;flex-direction:column;gap:8px}.filter-item{display:flex;gap:4px;width:100%}.filter-item label{color:var(--text-secondary);font-size:11px;font-weight:500;display:flex;align-items:center;min-width:45px}.filter-item select,.filter-item input[type=text]{padding:6px 8px;background:var(--bg-L1);border:1px solid var(--static-border-color);border-radius:4px;color:var(--text-primary);font-size:12px;transition:border-color .2s ease;width:100%;box-sizing:border-box}.filter-item select:focus,.filter-item input[type=text]:focus{outline:none;border-color:var(--color-primary)}.filter-item select option{background:var(--bg-L1);color:var(--text-primary)}.range-inputs{display:flex;align-items:center;gap:4px;width:100%}.range-inputs input{flex:1;min-width:0}.range-inputs span{color:var(--static-text-muted);font-size:12px;flex-shrink:0}.search-button-container{padding:10px 12px}.search-btn{width:100%;padding:8px;background:var(--color-primary);color:var(--text-filled-btn);border:none;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s ease}.search-btn:hover{background:var(--color-primary-hover)}.search-results{padding:10px 12px;border-top:2px solid var(--border-medium);color:var(--text-primary);flex:3;overflow-y:auto;display:flex;flex-direction:column;min-height:100px}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(68,68,68,.5)}.results-header h4{color:var(--text-primary);font-size:13px;font-weight:700;margin:0}.results-count{color:var(--color-primary);font-size:12px;font-weight:600}.results-list{display:flex;flex-direction:column;gap:8px;flex:1}.result-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--bg-popup-highlight);border:1px solid var(--border-soft);color:var(--text-primary);border-radius:6px;transition:all .2s ease;cursor:pointer}.result-item:hover{background:#4a90e226;border-color:var(--color-primary)}.result-content{display:flex;flex-direction:column;gap:4px;flex:1}.result-name{color:var(--text-primary);font-size:1.1rem;font-weight:700}.result-address{color:var(--text-tertiary);font-size:.9rem;line-height:1.4}.result-capacity{color:var(--color-primary);font-size:11px;font-weight:600;margin-top:2px}.result-actions{display:flex;align-items:center}.favorite-icon{color:var(--static-text-muted);font-size:20px!important;cursor:pointer;transition:all .2s ease}.favorite-icon:hover{color:var(--color-warning);transform:scale(1.15)}.favorite-icon.favorited{color:var(--color-warning)}@keyframes searchChromeSlideIn{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes searchChromeSlideOut{0%{transform:translate(0);opacity:1}to{transform:translate(-100%);opacity:0}}.search-results-container{position:absolute;z-index:15;background:var(--bg-L3);top:80px;left:0;width:320px;height:90vh;box-shadow:0 2px 8px #0000001a;color:#fff;display:flex;flex-direction:column}.search-results-container:not(.slide-out){animation:searchChromeSlideIn .2s ease-out}.search-results-container.slide-out{animation:searchChromeSlideOut .2s ease-in;animation-fill-mode:forwards}.panel-close-icon{position:absolute;left:317px;color:var(--text-secondary);background:var(--bg-L3);cursor:pointer;z-index:20;font-size:30px!important;transition:color .2s ease}.panel-close-icon:hover{color:var(--text-primary)}.search-results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid #34495e;color:#fff}.search-results-header h3{color:#fff;margin:0;font-size:1.1rem;font-weight:600}.result-count{font-size:.9rem;padding:4px 8px}.search-results-list{display:flex;flex-direction:column;gap:12px;overflow-y:auto;flex:1;min-height:0}.search-result-item{padding:8px;display:flex;justify-content:space-between;align-items:flex-start;transition:transform .2s ease,box-shadow .2s ease}.search-result-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026;background-color:var(--static-bg-4)}.result-content{flex:1}.result-capacity{font-size:.85rem;color:var(--text-secondary)}.result-actions{margin-left:12px}.favorite-icon{color:var(--static-text-secondary);cursor:pointer;transition:color .2s ease;font-size:1.2rem}.favorite-icon:hover,.favorite-icon.favorited{color:var(--color-warning)}.detail-search-container{position:absolute;z-index:3;background:#fff;border-radius:8px;top:60px;width:90%;max-width:1100px;padding:10px;box-shadow:0 2px 8px #0000001a;max-height:90vh;overflow-y:auto}.detail-search-content{width:100%}.detail-search-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid #34495e}.detail-search-header h3{color:#2c3e50;margin:0;font-size:1.1rem;font-weight:600}.detail-search-body{padding:0}.search-filters{margin-bottom:30px}.filter-row{display:flex;gap:20px;margin-bottom:15px;flex-wrap:wrap}.filter-group{display:flex;flex-direction:row;align-items:center;min-width:200px;flex:1;gap:10px}.filter-group label{font-weight:600;margin:0;color:#333;font-size:.9rem;flex-shrink:0}.filter-group select,.filter-group input{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:.9rem;flex:1;width:100%;box-sizing:border-box}.filter-group input{margin:0}.filter-group span{margin:0 5px;color:#666;font-weight:500}.range-inputs{display:flex;align-items:center;gap:5px;flex:1}.range-inputs input{flex:1;margin:0}.search-button-container{display:flex;justify-content:flex-end;margin-top:20px}.results-header{margin-bottom:15px}.results-table{overflow-x:auto;color:#000;border:1px solid #ddd;border-radius:4px}.results-table table{width:100%;border-collapse:collapse;min-width:1000px}.results-table th,.results-table td{padding:12px 8px;text-align:left;border-bottom:1px solid #eee}.results-table th{background-color:#f8f9fa;font-weight:600;color:#333;position:sticky;top:0;z-index:10;font-size:.75rem}.results-table td{font-size:.85rem;align-items:center}.results-table tr:hover{background-color:#f5f5f5}.detail-search-panel-root{position:relative;height:75vh;min-width:600px;padding:var(--spacing-lg) var(--spacing-md) var(--spacing-md);color:var(--text-primary)}.detail-search-panel-close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);color:var(--text-secondary);cursor:pointer;z-index:2;font-size:26px!important;transition:color .2s ease}.detail-search-panel-close:hover{color:var(--text-primary)}.search-panel-content--row{flex-direction:row!important;align-items:stretch;min-height:min(70vh,520px);max-height:75vh}.search-panel-content--row .search-categories{flex:0 0 min(280px,38vw);max-width:320px;overflow-x:hidden;overflow-y:auto}.search-results--column{flex:1;flex-shrink:0;min-width:300px;border-top:none!important;max-height:none;min-height:0}.detail-search-results-empty{padding:var(--spacing-lg);text-align:center;color:var(--text-tertiary);font-size:13px}.panel-section-title{display:flex;justify-content:space-between;align-items:center;font-size:16px;font-weight:600;color:var(--text-primary);padding-bottom:2px;margin:0 0 4px}.weather-warnings-section{background-color:var(--bg-popup-highlight);border:1px solid var(--border-soft);border-radius:8px;padding:6px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);overflow:auto}.more-btn{background:none;border:none;color:var(--text-primary);font-size:12px;cursor:pointer;text-decoration:underline}.more-btn:hover{color:var(--text-tertiary)}.more-btn.active{color:var(--color-primary);font-weight:600}.empty-section{display:flex;flex-direction:column;align-items:center;justify-content:center}.status-btn{padding:4px 8px;font-size:11px;border-radius:4px;border:none;font-weight:500;cursor:pointer;align-self:flex-start}.status-normal{background-color:var(--color-success);color:var(--text-primary)}.status-warning{background-color:var(--color-warning);color:#000}.status-danger{background-color:var(--color-danger);color:var(--text-primary)}.status-caution{background-color:var(--color-caution);color:var(--text-primary)}.status-disconnected{background-color:var(--color-info);color:var(--text-primary)}.panel-close-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:5px}.panel-close-btn:hover{color:var(--text-primary)}.weather-info-title{font-weight:600}.weather-info-container{display:flex;flex-direction:column;padding:var(--spacing-sm);gap:var(--spacing-xs);background-color:rgb(from var(--bg-L1) r g b / .5);border-radius:8px}.weather-info-container.collapsed .weather-warnings,.weather-info-container.collapsed .section.over-scroll,.section.facility-status-section.collapsed .facility-status,.section.favorite-facilities-section.collapsed .facility-table,.section.right-panel-charts-section.collapsed .charts-container,.section.right-panel-charts-section.collapsed .bar-chart-container,.section.right-panel-weather-section.collapsed .empty-section{display:none}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 var(--spacing-xs)}.weather-warnings{display:flex;gap:8px}.weather-warnings .weather-warnings-section{flex:1 1 0;display:flex;flex-direction:column;justify-content:center;align-items:start;margin:0;padding:var(--spacing-xs) var(--spacing-sm)}.weather-warnings .section span{text-align:start;font-weight:700}.weather-warnings-info{width:100%;display:flex;align-items:center;justify-content:space-between;font-size:11px;gap:var(--spacing-xs)}.tag-btn:hover{background-color:var(--bg-hover)}.info-list{display:flex;flex-direction:column;overflow-y:auto;gap:var(--spacing-sm);max-height:210px}.info-item{display:flex;gap:8px;padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--border-strong)}.info-stat{flex:25}.info-detail{flex:75;font-size:12px;color:var(--text-secondary);line-height:1.4}.info-detail b{color:var(--text-primary)}.info-detail a{color:var(--text-secondary);font-weight:600}.facility-status{display:flex;flex-direction:column;gap:var(--spacing-md)}.facility-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-lg);padding:var(--spacing-xs);border-bottom:1px solid var(--border-medium);font-size:12px;cursor:pointer}.facility-item:hover{background:var(--bg-L4)}.facility-name{font-weight:600;color:var(--text-primary)}.facility-time{font-size:12px;color:var(--text-secondary)}.facility-datetime{font-size:12px;color:var(--text-primary)}.facility-table{display:flex;flex-direction:column;gap:4px}.facility-table-body{display:flex;flex-direction:column;gap:4px;overflow-y:auto;max-height:250px}.col-facility{text-align:left}.col-data,.col-status,.col-star{text-align:center}.status-cell,.star-cell{display:flex;justify-content:center;align-items:center}.facility-info{display:flex;flex-direction:column;gap:2px}.facility-location{font-size:11px;color:var(--text-secondary);margin-top:2px}.status-buttons{display:flex;align-items:center;gap:8px}.star-icon{font-size:16px;color:var(--color-warning)}.charts-container{display:flex;flex-direction:row;gap:15px;margin-bottom:10px;justify-content:space-between}.chart-item{display:flex;justify-content:center;flex:1}.circular-chart{display:flex;flex-direction:column;align-items:center;gap:8px;border:1px solid rgb(from var(--border-medium) r g b / .5);border-radius:8px;padding:10px;width:100%}.chart-circle{width:60px;height:60px;display:flex;align-items:center;justify-content:center;position:relative}.chart-svg{width:100%;height:100%;position:absolute;top:0;left:0}.chart-background{stroke:#444;stroke-width:8;fill:none}.chart-progress{stroke:var(--color-primary);stroke-width:8;fill:none;stroke-linecap:round;transition:stroke-dasharray .3s ease}.chart-percentage{position:relative;z-index:1;font-size:12px;font-weight:600;color:var(--text-primary)}.chart-label{font-size:10px;text-align:center;font-weight:500;line-height:1.2}.chart-details{display:flex;gap:8px;font-size:10px}.achieved{color:var(--color-primary)}.bar-chart-container{border:1px solid rgb(from var(--border-medium) r g b / .5);border-radius:8px;padding:10px}.bar-chart{display:flex;height:180px;gap:3px;align-items:flex-end}.chart-y-axis{display:flex;flex-direction:column;justify-content:space-between;padding-right:6px;height:100%;min-width:25px}.y-label{font-size:10px;text-align:right;height:16px;display:flex;align-items:center;justify-content:flex-end}.chart-bars{display:flex;align-items:flex-start;gap:3px;flex:1;height:100%;padding-top:15px}.bar-group{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;flex:1;height:100%}.bar{width:100%;background-color:var(--color-primary);border-radius:0 0 1px 1px;min-height:2px;transition:height .3s ease}.bar-label{font-size:9px;margin-top:3px;text-align:center;writing-mode:horizontal-tb}.right-control-panel{margin-top:30px;display:flex;gap:10px}.situation-history{display:flex;flex-direction:column;gap:12px;max-height:300px}.situation-item{background-color:#3a3a3ab3;border:1px solid rgba(68,68,68,.5);border-radius:6px;padding:12px}.situation-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.situation-label{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;color:var(--text-primary)}.situation-timestamp{font-size:11px;color:var(--text-tertiary)}.situation-description{font-size:12px;color:#ddd;line-height:1.4}.alarm-button{background-color:var(--color-primary);color:var(--text-primary);border:none;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;margin-top:8px;align-self:flex-start}.alarm-button:hover{background-color:var(--color-primary-hover)}.alarm-issuance{background-color:#3a3a3ab3;border:1px solid rgba(68,68,68,.5);border-radius:6px;padding:15px}.alarm-title{font-size:14px;font-weight:600;color:#e74c3c;margin-bottom:8px;line-height:1.3}.alarm-description{font-size:12px;color:#ddd;margin-bottom:12px;line-height:1.4}.alarm-details{display:flex;flex-direction:column;gap:6px;margin-bottom:15px}.detail-item{display:flex;gap:8px;font-size:12px}.detail-label{color:var(--text-tertiary);font-weight:500;min-width:60px}.detail-value{color:#ddd;flex:1}.alarm-actions{display:flex;align-items:center;gap:12px}.alarm-actions .save-button{background-color:var(--color-info);font-size:11px}.alarm-actions .save-button:hover{background-color:var(--color-info)}.issue-button{background-color:var(--color-danger);color:var(--text-primary);border:none;padding:6px 12px;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer}.issue-button:hover{background-color:var(--color-danger)}.issue-timestamp{font-size:11px;color:var(--text-tertiary);margin-left:auto}.downstream-info{background-color:#3a3a3ab3;border:1px solid rgba(68,68,68,.5);padding:12px}.downstream-table{display:flex;flex-direction:column;gap:4px}.downstream-table .table-header{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:8px;padding:8px 12px;background-color:#4a4a4acc;border-radius:4px;font-size:11px;font-weight:600;color:var(--text-tertiary);border:1px solid rgba(68,68,68,.5)}.downstream-table .table-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:8px;align-items:center;padding:8px 12px;background-color:#3a3a3ab3;border-radius:4px;border:1px solid rgba(68,68,68,.5);font-size:11px}.downstream-table .col-name{color:#ddd;font-weight:500}.downstream-table .col-population,.downstream-table .col-distance{color:var(--text-tertiary);text-align:center}.downstream-table .col-risk{display:flex;justify-content:center;align-items:center}.reservoir-popup{background:var(--text-primary);border-radius:12px;box-shadow:0 8px 32px #0000004d;width:250px!important;position:fixed;animation:popupSlideIn .3s ease-out;-webkit-user-select:none;user-select:none}.reservoir-popup.dragging{cursor:move;box-shadow:0 12px 40px #0006;color:var(--text-primary)}@keyframes popupSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.popup-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px 8px;border-bottom:1px solid var(--border-strong);cursor:move;background-color:var(--bg-L3);border-radius:12px 12px 0 0}.popup-header:hover{background-color:var(--bg-hover)}.popup-title{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:600;color:var(--text-primary)}.reservoir-popup .favorite-star{color:#ccc}.reservoir-popup .favorite-star.favorited,.reservoir-popup .favorite-star:hover{color:var(--color-warning)}.popup-close{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;color:var(--text-tertiary);transition:all .2s ease}.popup-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.popup-content{padding:10px 12px 12px;background:var(--bg-L3);color:var(--text-primary)}.popup-address{font-size:14px;color:var(--text-tertiary);margin-bottom:10px;line-height:1.4}.popup-status{display:flex;gap:12px;margin-bottom:10px}.status-item{display:flex;align-items:center;gap:8px}.status-label{font-size:14px;color:var(--text-primary);font-weight:500}.popup-menu{display:flex;flex-direction:column;gap:4px}.menu-item{background:none;border:none;padding:6px 8px;text-align:left;font-size:16px;color:var(--text-primary);cursor:pointer;border-radius:6px;transition:all .2s ease;font-weight:500}.menu-item:hover{background-color:var(--bg-hover);color:var(--color-primary)}.menu-item.active{background-color:#e3f2fd;color:#1976d2;font-weight:600}.menu-item.active:hover{background-color:var(--bg-hover)}.menu-item.disabled{opacity:.5;cursor:not-allowed;pointer-events:none;background:var(--bg-L6)}.status-overview{position:absolute;inset:0;display:grid;grid-template-columns:1fr 380px;gap:var(--spacing-lg);padding:var(--spacing-lg);background-color:var(--bg-L3);z-index:3}.facility-section{border:1px solid var(--border-soft);border-radius:8px;padding:var(--spacing-lg);display:flex;flex-direction:column;height:100%;max-height:100%;overflow-y:scroll}.summary-section{display:flex;flex-direction:column;background:var(--bg-L3);border:1px solid var(--border-soft);border-radius:8px;padding:var(--spacing-lg)}.filters{display:flex;gap:8px}.filter-btn{background:var(--bg-L4);color:var(--text-secondary);border:1px solid var(--border-soft);border-radius:6px;padding:6px 10px;cursor:pointer}.filter-btn.active{background:var(--bg-L1);color:var(--text-primary);border-color:var(--border-medium)}.facility-cards{padding:var(--spacing-sm);flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;display:flex;flex-direction:column;gap:var(--spacing-lg)}.facility-group{display:flex;flex-direction:column;gap:var(--spacing-md)}.facility-group-title{color:var(--text-primary);font-size:18px;font-weight:700;margin:0;padding:var(--spacing-sm) 0;border-bottom:2px solid var(--border-soft)}.facility-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--spacing-md);align-items:start}.facility-card-wrapper{display:flex;flex-direction:column;gap:0}.facility-card{background:var(--bg-L2);border:1px solid var(--border-soft);border-radius:8px;padding:var(--spacing-md);color:var(--text-secondary);cursor:pointer}.facility-card:hover{border:1px solid var(--color-primary-hover);transform:translateY(-2px);transition:all .1s ease;box-shadow:2px 2px 5px rgb(from var(--bg-L7) r g b / .5)}.facility-card-header{display:flex;justify-content:space-between;align-items:center}.facility-title{color:var(--text-primary);font-weight:700}.facility-status-chips{display:flex;justify-content:space-evenly;padding:var(--spacing-sm)}.facility-status-chips div{display:flex;flex-direction:column;gap:var(--spacing-sm)}.facility-status-chips div p{font-size:13px;font-weight:700}.facility-specs{font-size:13px;color:var(--text-tertiary);display:grid;gap:var(--spacing-sm)}.facility-specs-row{display:flex;justify-content:space-between}.senser-overview-btn{display:flex;align-items:center;justify-content:center;background:var(--bg-L5);border-radius:50%;border:1px solid var(--border-medium);height:25px;width:25px;cursor:pointer}.senser-overview-btn:hover{background:var(--color-primary)}.summary-panel{display:flex;flex-direction:column;gap:14px;height:100%}.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--border-soft);border-radius:8px;gap:10px}.summary-kpi{padding:var(--spacing-md);text-align:center}.kpi-value{color:var(--text-primary);font-size:22px;font-weight:800}.kpi-label{color:var(--text-tertiary);font-size:12px;margin-top:var(--spacing-xs)}.actions-log{border:1px solid var(--border-soft);border-radius:8px;display:flex;flex:1;flex-direction:column;overflow-y:auto}.log-item{padding:10px;display:flex;gap:var(--spacing-sm);align-items:center}.log-badge-wrapper{flex:3}.log-item:hover{background:var(--bg-hover)}.log-text{color:var(--text-secondary);font-size:12px;flex:8}.sensor-cards-container{position:fixed;width:max-content;background:var(--bg-L4);border:1px solid var(--border-soft);border-radius:8px;padding:var(--spacing-md);z-index:10;box-shadow:0 4px 12px #00000026;opacity:0;pointer-events:none;transition:opacity .1s ease}.sensor-cards-container.visible{opacity:1;pointer-events:auto}.sensor-cards-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs)}.sensor-cards-title{color:var(--text-primary);font-size:18px;font-weight:700;margin:0}.sensor-cards-close{background:transparent;border:none;color:var(--text-secondary);font-size:28px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.sensor-cards-close:hover{background:var(--bg-hover);color:var(--text-primary)}.sensor-cards-grid{display:flex;gap:var(--spacing-md)}.sensor-card{background:var(--bg-L3);border:1px solid var(--border-medium);border-radius:8px;padding:var(--spacing-md);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);transition:all .2s ease}.sensor-card:hover{background:var(--bg-hover);border-color:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.sensor-card-header{width:100%;text-align:center}.sensor-name{color:var(--text-primary);font-size:16px;font-weight:700}.sensor-status-icon{display:flex;align-items:center;justify-content:center;width:100px;height:100px;border-radius:50%;background:var(--bg-L3);border:2px solid var(--border-medium)}.sensor-card-info{width:100%;display:flex;flex-direction:column;gap:var(--spacing-xs);font-size:12px}.sensor-info-item{display:flex;gap:var(--spacing-xs);color:var(--text-tertiary)}.sensor-info-label{font-weight:600;min-width:50px}.facility-status-container{position:absolute;inset:0;background-color:var(--bg-L3);overflow:hidden}.fs-main-area{width:100%;height:100%;min-height:0;position:relative;overflow:hidden;background:var(--bg-L3)}.fs-alerts-route-fill{height:100%;min-height:0;display:flex;flex-direction:column;padding:var(--spacing-sm);box-sizing:border-box}.fs-grid-layout{display:grid;grid-template-columns:var(--grid-columns);grid-template-rows:var(--grid-rows);height:100%;position:relative}.fs-section-title{color:var(--text-primary);font-size:16px;font-weight:700;margin-bottom:var(--spacing-xs);border-bottom:2px solid var(--bg-L7)}.fs-sliding-panel{position:absolute;top:0;left:0;height:100%;background:var(--bg-L4);border-right:1px solid var(--border-soft);z-index:11;overflow-y:auto;overflow-x:hidden;animation:slideIn .3s ease-out}.fs-sliding-panel.closing{animation:slideOut .3s ease-in}@keyframes slideIn{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(-100%);opacity:0}}.fs-panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);border-bottom:2px solid var(--color-primary);background:var(--bg-L6);position:sticky;top:0;z-index:2}.fs-panel-header h3{color:var(--text-primary);font-size:14px;font-weight:700;margin:0}.fs-alert-panel{width:95%}.fs-alert-panel-content{display:flex;flex-direction:column;height:100%}.fs-download-btn{display:flex;align-items:center;padding:6px var(--spacing-md);background:var(--bg-L2);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.fs-download-btn:hover{background:var(--bg-hover);border-color:var(--color-primary)}.fs-alert-content{padding:var(--spacing-md);color:var(--text-tertiary);flex:1;overflow-y:auto;display:flex;flex-direction:column;background:var(--bg-popup-highlight)}.fs-alert-list-content{display:flex;flex-direction:column;border-radius:var(--radius-lg);flex:1;min-height:0;overflow:hidden}.fs-alert-list-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:2px solid var(--color-primary);position:sticky;top:0;z-index:2}.fs-alert-list-header h3{color:var(--text-primary);font-size:16px;font-weight:700;margin:0}.fs-toolbar-actions{display:flex;gap:8px;align-items:center}.fs-download-btn .fs-download-btn-leading-icon{font-size:16px;margin-right:4px}.fs-alert-grade{font-weight:600;color:var(--text-tertiary)}.fs-alert-grade[data-grade=경계]{color:var(--color-warning)}.fs-alert-grade[data-grade=위험]{color:var(--color-danger)}.fs-alert-grade[data-grade=주의]{color:var(--color-caution)}.fs-view-btn{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-L4);color:var(--text-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-sm);font-size:11px;font-weight:500;cursor:pointer;transition:all .2s ease}.fs-view-btn:hover{background:linear-gradient(rgb(from var(--color-primary) r g b / .3),rgb(from var(--color-primary) r g b / .3)),var(--bg-L4);border-color:var(--color-primary);color:var(--text-primary)}.fs-overview-root{position:absolute;inset:0;z-index:1;pointer-events:none}.fs-overview-root>*{pointer-events:auto}.fs-map-layer{position:absolute;inset:0;z-index:0;pointer-events:auto}.fs-map-layer .fs-map-section{border:none;border-radius:0}.fs-map-section{width:100%;height:100%;background:var(--bg-L4);border:1px solid var(--border-soft);display:flex;position:relative;gap:0;overflow:hidden;padding:0}.fs-map-section--fullscreen{width:100%;height:100%;border:none;border-radius:0}.fs-info-section{padding:var(--spacing-sm) var(--spacing-md);display:flex;flex-direction:column}.fs-info-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,1fr);gap:var(--spacing-sm);flex:1}.fs-info-item{display:flex;gap:var(--spacing-xs);padding:var(--spacing-xs);background:var(--bg-popup-highlight);border:1px solid var(--border-soft);border-radius:var(--radius-sm)}.fs-info-label{display:flex;align-items:center;gap:var(--spacing-xs);font-size:12px;color:var(--text-tertiary);font-weight:500}.fs-info-value{display:flex;align-items:center;font-size:14px;color:var(--text-primary);font-weight:600}.fs-sensor-section{border:1px solid var(--border-soft);padding:var(--spacing-sm) var(--spacing-md);display:flex;flex-direction:column;border-radius:var(--radius-md)}.fs-sensor-list{flex:1}.fs-sensor-item{background:var(--bg-L2);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:var(--spacing-sm);display:flex;flex-direction:column;transition:all .1s ease;justify-content:space-between;height:90%}.fs-sensor-item-selected{border:3px solid var(--color-primary);transform:translateY(-2px);scale:1.05}.fs-sensor-icon-wrap{display:flex;justify-content:center}.fs-sensor-name{display:flex;align-items:center;justify-content:space-between;color:var(--text-primary);font-size:14px;font-weight:700;text-align:center;border-bottom:1px solid var(--border-medium)}.fs-sensor-name--flat{justify-content:center;border-bottom:1px solid var(--border-medium);padding-bottom:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.fs-sensor-name--flat span{font-size:12px;line-height:1.25}.fs-sensor-chevron{cursor:pointer;transition:all .2s ease}.fs-sensor-chevron:hover{color:var(--color-primary)}.fs-sensor-status-grid{display:flex;justify-content:space-evenly;padding:0 var(--spacing-sm);gap:var(--spacing-xs)}.fs-sensor-status-item{display:flex;flex-direction:column;gap:var(--spacing-sm)}.fs-sensor-status-label{font-size:11px;color:var(--text-tertiary)}.fs-chart-section{border:1px solid var(--border-soft);display:flex;flex-direction:column;min-height:0}.fs-chart-section--tooltip{min-height:200px;border:none;background:transparent}.fs-chart-section--tooltip .fs-chart-container{min-height:200px}.fs-chart-container{flex:1;display:flex;justify-content:center;align-items:center;height:100%}.fs-cctv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm);flex:1;height:100%}.fs-cctv-item{position:relative;overflow:hidden;height:95%;cursor:pointer;border-radius:var(--radius-md);border:2px solid transparent;transition:border-color .2s ease,box-shadow .2s ease}.fs-cctv-item:hover{border-color:var(--border-medium)}.fs-cctv-item-selected{border-color:var(--color-primary)}.fs-cctv-video{width:100%;height:100%;object-fit:cover;display:block;border-radius:var(--radius-md)}.fs-cctv-name{position:absolute;top:var(--spacing-sm);left:var(--spacing-sm);background:rgb(from var(--bg-L5) r g b / .92);color:var(--text-primary);font-size:12px;font-weight:700;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm)}.fs-cctv-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:rgb(from var(--bg-L2) r g b / .88);color:var(--text-muted);font-size:14px;font-weight:500}.fs-map-marker-toggle-wrap{position:absolute;top:62px;right:12px;z-index:12;pointer-events:auto}.fs-map-marker-toggle-stack{display:flex;flex-direction:column;align-items:center;gap:8px}.fs-map-marker-toggle-btn{display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;width:40px;height:36px;margin:0;padding:0;border-radius:4px;border:1px solid var(--border-soft);background:rgb(from var(--bg-L4) r g b / .88);color:var(--text-primary);cursor:pointer}.fs-map-marker-toggle-btn:hover{background:rgb(from var(--bg-L5) r g b / .9);border-color:var(--border-medium)}.fs-overlay-toolbar{position:absolute;top:var(--spacing-md);left:var(--spacing-md);z-index:12;display:flex;flex-direction:column;gap:var(--spacing-sm);pointer-events:auto}.fs-overlay-toolbar .MuiIconButton-root{background:rgb(from var(--bg-L4) r g b / .88);color:var(--text-primary);border:1px solid var(--border-soft)}.fs-overlay-toolbar .MuiIconButton-root:hover{background:rgb(from var(--bg-L5) r g b / .9);border-color:var(--border-medium)}.fs-bottom-dock-wrapper{position:absolute;left:0;right:0;bottom:0;z-index:14;display:flex;flex-direction:column-reverse;align-items:stretch;pointer-events:none}.fs-bottom-dock-wrapper>*{pointer-events:auto}.fs-bottom-dock{width:100%;display:flex;flex-direction:column;background:rgb(from var(--bg-L2) r g b / .8);border-top:1px solid var(--border-soft);height:25vh;overflow:hidden}.fs-bottom-dock-header-row{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-xs);flex-shrink:0;width:100%;box-sizing:border-box;padding:2px var(--spacing-sm);min-height:32px}.fs-bottom-dock-tabs-wrap{flex:0 0 auto;width:auto;max-width:fit-content}.fs-bottom-dock-tabs-wrap .MuiTabs-root{width:auto;max-width:max-content}.fs-bottom-dock-toggle{flex-shrink:0;align-self:center;width:44px;height:28px;border-radius:var(--radius-md) var(--radius-md) 0 0;background:rgb(from var(--bg-L2) r g b / .7);border:1px solid var(--border-soft);border-bottom:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);padding:0;box-sizing:border-box}.fs-bottom-dock-toggle:hover{color:var(--text-primary);border-color:var(--border-medium);background:rgb(from var(--bg-L4) r g b / .92)}.fs-bottom-dock-tabs{min-height:32px;border-bottom:none;width:auto;max-width:max-content}.fs-bottom-dock-tabs .MuiTabs-indicator{height:2px}.fs-bottom-dock-tabs .MuiTab-root{color:var(--text-secondary);text-transform:none;font-weight:600}.fs-bottom-dock-tabs .Mui-selected{color:var(--color-primary)}.fs-bottom-dock-body{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column;padding:var(--spacing-xs) var(--spacing-sm) var(--spacing-sm)}.fs-bottom-dock-body--cctv,.fs-bottom-dock-body--sensor{flex-direction:row;flex-wrap:nowrap;gap:var(--spacing-sm);overflow-x:auto;overflow-y:hidden;align-items:center;align-content:center}.fs-bottom-dock-body--cctv .fs-cctv-item{flex:0 0 auto;max-height:22vh}.fs-bottom-dock-body--sensor .fs-sensor-item{flex:0 0 auto;min-width:120px;max-width:148px}.fs-map-tooltip-backdrop{position:absolute;inset:0;z-index:11;background:var(--bg-L1);pointer-events:auto}.fs-map-tooltip-card{position:absolute;width:min(420px,calc(100% - 24px));max-width:calc(80vw - 24px);max-height:max(520px,78vh);z-index:13;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-popup-background);border:1px solid var(--border-medium);border-radius:var(--radius-lg);pointer-events:auto;-webkit-user-select:none;user-select:none}.fs-map-tooltip-card--dragging{cursor:grabbing}.fs-map-tooltip-header{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-sm) var(--spacing-xs);border-bottom:1px solid rgb(from var(--border-soft) r g b / .5);flex-shrink:0;cursor:grab}.fs-map-tooltip-card--dragging .fs-map-tooltip-header{cursor:grabbing}.fs-map-tooltip-drag-icon{color:var(--text-muted);flex-shrink:0;opacity:.85}.fs-map-tooltip-title{flex:1;min-width:0;line-height:1.3;color:var(--text-primary)}.fs-map-tooltip-header .fs-map-tooltip-title.MuiTypography-root{font-size:1rem}.fs-map-tooltip-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-md);-webkit-user-select:text;user-select:text}.fs-map-tooltip-info{display:flex;flex-direction:column;gap:0;border:1px solid var(--border-soft);border-radius:var(--radius-md);background:var(--bg-popup-highlight)}.fs-map-tooltip-row{display:grid;grid-template-columns:92px minmax(0,1fr);gap:var(--spacing-sm);align-items:start;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border-soft)}.fs-map-tooltip-row:last-child{border-bottom:none}.fs-map-tooltip-label{font-size:12px;font-weight:600;color:var(--text-tertiary);letter-spacing:.02em;line-height:1.4}.fs-map-tooltip-value{font-size:13px;font-weight:500;color:var(--text-primary);line-height:1.45;word-break:break-word}.fs-map-tooltip-cctv-video{width:100%;max-height:200px;border-radius:var(--radius-md);background:var(--bg-L1)}.fs-map-tooltip-card--all-sensors{width:min(840px,calc(100% - 24px));max-height:max(520px,78vh)}.fs-map-tooltip-body--all-sensors-grid{display:flex;flex-direction:column;gap:var(--spacing-sm);min-height:0}.fs-all-sensors-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:repeat(3,minmax(0,1fr));gap:var(--spacing-sm);min-height:0;flex:1}.fs-all-sensors-grid-cell{min-width:0;min-height:0;display:flex;flex-direction:column;border:1px solid var(--border-soft);border-radius:var(--radius-md);background:var(--bg-popup-highlight);padding:var(--spacing-xs)}.fs-all-sensors-grid-cell--selected{border-color:var(--color-primary);box-shadow:0 0 0 1px rgb(from var(--color-primary) r g b / .35)}.fs-chart-section--clickable .fs-section-title,.fs-chart-section--clickable .fs-chart-container{cursor:pointer}.fs-chart-section--grid-cell{flex:0 0 auto;min-height:0}.fs-chart-section--grid-cell .fs-section-title{font-size:.75rem;font-weight:600;margin-bottom:4px}.fs-chart-section-title-row{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:var(--spacing-xs);margin-bottom:4px;min-width:0}.fs-chart-section-title-text{font-size:.75rem;font-weight:600;color:var(--text-primary);line-height:1.3;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fs-chart-section-detail-btn{flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:600;line-height:1.4;border-radius:var(--radius-sm);border:1px solid var(--border-medium);background:rgb(from var(--bg-L4) r g b / .95);color:var(--text-primary);cursor:pointer}.fs-chart-section-detail-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--bg-popup-highlight)}.fs-chart-section-detail-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.fs-chart-section--grid-cell .fs-chart-container{flex:0 0 auto;height:140px;min-height:120px}.fs-all-sensors-pagination{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:var(--spacing-xs);flex-shrink:0;padding-top:var(--spacing-xs);border-top:1px solid rgb(from var(--border-soft) r g b / .5)}.monitoring-image-section{grid-column:1 / 49;grid-row:1 / 49;overflow:hidden}.monitoring-image-section .tmp-img{object-fit:cover;height:100%;width:100%}.monitoring-tmp-container--water-lv{grid-column:8 / 10;grid-row:9 / 12}.monitoring-tmp-container--water-leak{grid-column:3 / 5;grid-row:12 / 15}.monitoring-tmp-container--displacement{grid-column:16 / 18;grid-row:6 / 9}.monitoring-hotspot-img{object-fit:cover;height:100%;width:100%;cursor:pointer}.monitoring-graph-section{grid-column:49 / 97;grid-row:1 / 25;display:flex;flex-direction:column;padding:12px}.monitoring-history-section{grid-column:49 / 97;grid-row:25 / 49;display:flex;flex-direction:column}.monitoring-tmp-container{display:flex;flex-direction:column}.monitoring-tmp-container img{flex:2}.monitoring-tmp-label{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-L5);color:var(--text-tertiary);border-radius:20px;cursor:pointer;transition:all .3s ease}.monitoring-tmp-label-selected{background-color:var(--bg-L1);color:var(--text-primary);border:3px solid var(--color-primary)}.chart-controls{display:flex;justify-content:start;align-items:center;gap:16px;flex-wrap:wrap}.date-controls{display:flex;gap:16px;align-items:center}.date-control-btn{padding:var(--spacing-xs) var(--spacing-lg)!important}.date-label{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-primary);font-size:14px;font-weight:500}.sensor-selection-controls{display:flex;justify-content:end;padding-right:16px}.sensor-controls{display:flex;gap:8px}.sensor-button{padding:8px 16px;background-color:var(--bg-L4);color:var(--text-tertiary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.sensor-button:hover{background-color:var(--bg-hover);border-color:var(--color-primary);color:var(--text-primary)}.sensor-button.active{background-color:var(--color-primary);border-color:var(--color-primary-hover);color:var(--text-primary)}.chart-container{flex:1;min-height:0;width:100%}.history-empty{display:flex;align-items:center;justify-content:center;height:100%;padding:40px}.history-empty-text{color:var(--text-muted);font-size:14px;margin:0}.event-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto}.event-item{display:grid;grid-template-columns:96px 1fr;gap:10px;align-items:start;background:var(--bg-L1);border:1px solid var(--border-soft);padding:10px}.event-badge{display:inline-flex;align-items:center;justify-content:center;font-weight:800;color:var(--text-primary);border-radius:6px;padding:8px 10px;height:28px}.event-badge.caution{background:var(--color-caution)}.event-badge.storm{background:var(--color-danger)}.event-badge.danger{background:var(--bg-L6)}.event-body{display:flex;flex-direction:column;gap:6px}.event-title-line{display:flex;gap:8px;align-items:baseline}.event-datetime{color:var(--color-primary);font-weight:700}.event-title{color:var(--text-secondary);font-weight:800}.event-title.danger{color:var(--color-danger)}.event-title.warning{color:var(--color-warning)}.event-highlight{color:var(--color-danger);font-weight:700}.event-desc{color:var(--text-secondary);line-height:1.35}.event-contact{color:var(--text-muted);font-size:12px}.zone-map{grid-column:1 / 75;grid-row:1 / 49;position:relative;overflow:hidden;padding:0!important}.event-detection-popup{position:absolute;width:500px;max-height:600px;background:var(--bg-L3);border:1px solid var(--border-soft);border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:12;display:flex;flex-direction:column;-webkit-user-select:none;user-select:none}.event-detection-popup-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-L2);border-bottom:1px solid var(--border-soft);border-radius:8px 8px 0 0;cursor:move}.event-detection-popup-header:hover{background:var(--bg-hover)}.event-detection-popup-header .grid-section-title{margin:0;padding:0;font-size:16px}.event-detection-popup-controls{display:flex;gap:8px;align-items:center}.event-detection-popup-toggle{background:transparent;border:1px solid var(--border-medium);border-radius:4px;color:var(--text-primary);width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;transition:background-color .2s;flex-shrink:0}.event-detection-popup-toggle:hover{background:var(--bg-hover)}.event-detection-popup-controls{cursor:default}.event-detection-popup .event-list{padding:12px;overflow-y:auto;flex:1;min-height:0}.event-detection-popup-fab{position:absolute;left:20px;top:20px;z-index:13;width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--bg-L3);border:1px solid var(--border-medium);border-radius:8px;color:var(--text-primary);box-shadow:0 4px 12px #0000004d;cursor:pointer;transition:background-color .2s}.event-detection-popup-fab:hover{background:var(--bg-hover)}.sensor-1{grid-column:33 / 43;grid-row:1 / 17}.sensor-2{grid-column:43 / 53;grid-row:1 / 17}.sensor-3{grid-column:33 / 43;grid-row:17 / 33}.sensor-4{grid-column:43 / 53;grid-row:17 / 33}.sensor-5{grid-column:33 / 43;grid-row:33 / 49}.sensor-6{grid-column:43 / 53;grid-row:33 / 49}.sensor-status-content{display:flex;flex-direction:column;gap:8px;padding:4px 0}.sensor-comp-status{display:flex;align-items:center;justify-content:center}.sensor-info-item{display:flex;gap:6px;align-items:center;font-size:11px}.sensor-info-label{color:var(--text-muted);font-weight:500;min-width:60px;flex-shrink:0}.sensor-info-value{color:var(--text-secondary);flex:1}.sensor-status-items{display:flex;flex-direction:column;gap:6px;margin-top:4px;padding-top:8px;border-top:1px solid var(--border-strong)}.sensor-status-item{display:flex;justify-content:space-between;align-items:center;font-size:11px}.sensor-status-label{color:var(--text-tertiary);font-weight:500}.cctv{grid-column:53 / 75}.cctv-1{grid-row:1 / 17}.cctv-2{grid-row:17 / 33}.cctv-3{grid-row:33 / 49}.control-panel-section{grid-column:75 / 97;grid-row:1 / 49;overflow-y:auto;padding:8px}.control-panel-content{display:flex;flex-direction:column;height:100%}.control-subsection{border-radius:6px;padding:var(--spacing-sm);flex-shrink:0}.control-subsection:last-child{flex:1;display:flex;flex-direction:column;min-height:0}.control-subsection .grid-section-title{font-size:14px;margin-bottom:10px;padding-bottom:6px}.alert-message-wrapper{display:flex;flex-direction:column;gap:8px;flex:1;min-height:0}.alert-message-header{display:flex;justify-content:flex-end;align-items:center}.alert-message-length{font-size:11px;color:var(--text-muted)}.alert-message-textarea{flex:1;background-color:var(--bg-L2);border:1px solid var(--border-soft);border-radius:4px;padding:10px;color:var(--text-primary);font-size:12px;font-family:inherit;line-height:1.5;resize:none;min-height:150px}.alert-message-textarea:focus{outline:none;border-color:var(--color-primary);background-color:var(--bg-L2)}.alert-message-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.alert-attach-button,.alert-dispatch-button{padding:6px var(--spacing-lg);color:var(--text-filled-btn);border:none;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .2s}.alert-attach-button,.alert-attach-button:hover{background-color:var(--color-info)}.alert-dispatch-button{background-color:var(--color-primary)}.alert-dispatch-button:hover{background-color:var(--color-primary-hover)}.polygon-tooltip{position:absolute;background:var(--bg-L3);color:var(--text-primary);padding:8px 12px;border-radius:4px;font-size:12px;z-index:10;white-space:pre;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 12px #0006}.resource-grid{display:grid;grid-template-columns:var(--grid-columns);grid-template-rows:var(--grid-rows);gap:8px;height:100%;padding:var(--grid-padding)}.col-left{border:1px solid var(--border-soft);grid-column:1 / 33;grid-row:1 / 49}.col-center{border:1px solid var(--border-soft);grid-column:33 / 49;grid-row:1 / 49}.col-right{border:1px solid var(--border-soft);grid-column:49 / 97;grid-row:1 / 49}.site-situation{background-color:#3a3a3a66;width:100%;height:100%;display:flex;flex-direction:column;padding:16px;box-sizing:border-box;overflow-y:auto}.site-situation-title{margin:0 0 20px;font-size:20px;letter-spacing:.5px;color:var(--text-secondary);border-bottom:1px solid var(--border-soft);padding-bottom:10px}.site-situation-content{display:flex;flex-direction:column;gap:20px}.site-info-item{display:flex;gap:10px;align-items:baseline}.site-info-label{color:var(--text-muted);font-size:14px;font-weight:600;min-width:60px}.site-info-value{color:var(--text-secondary);font-size:14px}.site-alert-section{display:flex;flex-direction:column;gap:8px;background:#ffffff0f;border:1px solid rgba(68,68,68,.5);border-radius:6px;padding:12px}.site-alert-label{color:var(--text-muted);font-size:14px;font-weight:600}.site-alert-content{display:flex;flex-direction:column;gap:6px}.site-alert-time{color:#4a90e2;font-weight:700;font-size:13px}.site-alert-title{color:#ff4d4f;font-weight:800;font-size:14px}.site-alert-detail{color:#ff4d4f;font-weight:700;font-size:13px;margin-top:4px}.site-map-section{display:flex;flex-direction:column;gap:10px}.site-map-label{color:var(--text-muted);font-size:14px;font-weight:600}.site-map-image-wrapper{width:100%;border:1px solid rgba(68,68,68,.5);overflow:hidden;background:#0000004d}.site-map-image{width:100%;height:auto;display:block;object-fit:contain}.resource-status-content{background-color:#3a3a3a66;border:1px solid var(--border-soft);grid-column:4 / 97;grid-row:1 / 49;display:flex;flex-direction:column;overflow:hidden}.deployment-status{background:var(--bg-L3);width:100%;height:100%;display:flex;flex-direction:column;padding:var(--spacing-xs)!important;box-sizing:border-box;border:1px solid var(--border-soft);grid-column:4 / 20;grid-row:1 / 49}.deployment-status-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.resource-section{display:flex;flex-direction:column;gap:14px}.resource-section-title{margin:0;font-size:15px;font-weight:700;letter-spacing:.02em;color:var(--text-primary);display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:10px 12px;background:var(--bg-L3);border-bottom:2px solid var(--border-soft);transition:background .2s ease,border-color .2s ease}.resource-section-title:hover{background:var(--bg-L5);border-color:var(--color-primary)}.resource-section-title svg{flex-shrink:0;font-size:20px;color:var(--text-muted);opacity:.9;transition:transform .2s ease}.resource-section-toggle-icon{font-size:12px;color:var(--text-muted);margin-left:8px;transition:transform .2s}.resource-list{display:flex;flex-direction:column;gap:12px}.resource-item{border:1px solid var(--border-soft);background:var(--bg-L2);border-radius:8px;padding:8px 10px;display:flex;flex-direction:row;align-items:stretch;gap:12px;cursor:default;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease;box-shadow:0 1px 2px #0000002e}.resource-item.draggable{cursor:grab}.resource-item.draggable:hover{background:var(--bg-L3);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 6px 16px #00000040,0 0 0 1px var(--color-primary)}.resource-item.draggable:active{cursor:grabbing;transform:translateY(0)}.resource-item.dragging{opacity:.6;transform:scale(.98);border-color:var(--color-primary);box-shadow:0 0 16px var(--color-primary);background:var(--bg-L3)}.resource-item-layout{display:flex;width:100%;gap:12px}.resource-item-main{display:flex;flex-direction:column;justify-content:center;gap:6px;min-width:0;flex:2}.resource-item-title{display:flex;flex-direction:column;gap:4px}.resource-icon{font-size:1em}.resource-name{font-size:14px;font-weight:700;color:var(--text-primary)}.resource-total-badge{font-size:11px;font-weight:600;color:var(--text-muted)}.resource-item-metrics{display:flex;flex-direction:column;gap:6px;flex:3}.resource-metric-row,.resource-stat{display:flex;align-items:center;gap:8px}.resource-stat-label{font-size:12px;font-weight:600;color:var(--text-muted);min-width:40px}.resource-stat-value{font-size:13px;font-weight:700;color:var(--text-primary)}.resource-new-row{display:flex;align-items:center;gap:8px}.resource-new-label{font-size:12px;font-weight:600;color:var(--text-muted);min-width:60px}.resource-stepper{display:flex;align-items:center;gap:4px}.resource-stepper-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;flex-shrink:0;background:var(--bg-L2);border:1px solid var(--border-soft);border-radius:4px;color:var(--text-primary);cursor:pointer;transition:background-color .15s,border-color .15s,opacity .15s}.resource-stepper-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-medium)}.resource-stepper-btn:disabled{opacity:.4;cursor:not-allowed}.resource-info-input{width:60px;padding:4px 8px;background:var(--bg-L1);border:1px solid var(--border-soft);border-radius:4px;color:var(--text-primary);font-size:13px;font-weight:600;text-align:center}.resource-info-input:focus{outline:none;border-color:var(--color-primary)}.deploy-map{background-color:var(--bg-L3);position:relative;overflow:hidden;border:1px solid var(--border-soft);grid-column:20 / 97;grid-row:1 / 49}.deploy-map-buttons-wrapper{position:absolute;top:20px;left:10px;z-index:12;display:flex;align-items:center;gap:8px}.deploy-map-buttons-slider{overflow:hidden;transition:max-width .3s ease-out,opacity .25s ease}.deploy-map-buttons-wrapper.collapsed .deploy-map-buttons-slider{max-width:0;opacity:0}.deploy-map-buttons-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px;min-height:32px;padding:0;background:var(--bg-L3);border:1px solid var(--border-soft);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.deploy-map-buttons-toggle:hover{background:var(--bg-hover);border-color:var(--color-primary);color:var(--color-primary)}.deploy-map-buttons{display:flex;gap:8px;align-items:center}.deploy-map-btn{background-color:var(--bg-L1);border:1px solid var(--border-soft);border-radius:4px;padding:6px var(--spacing-md);font-size:13px;color:var(--text-secondary);font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.deploy-map-btn:hover{background-color:#4a90e2cc;border-color:var(--color-primary);color:var(--text-primary)}.deploy-map-btn.active{background-color:#4a90e2e6;border-color:var(--color-primary);color:var(--text-primary);box-shadow:0 0 8px #4a90e299}.address-marker-popup-overlay{position:absolute;top:64px;left:10px;right:10px;z-index:11;max-height:650px;pointer-events:none;display:flex;justify-content:flex-start}.address-marker-popup{pointer-events:auto;background:rgb(from var(--bg-L2) r g b / .95);border:1px solid var(--border-soft);border-radius:8px;box-shadow:0 10px 24px #00000059;padding:12px;display:flex;flex-direction:column;gap:12px}.address-marker-popup-header{display:flex;align-items:center;justify-content:space-between;color:var(--text-primary);font-size:14px}.address-marker-popup-close{border:1px solid var(--border-soft);background:var(--bg-L1);color:var(--text-secondary);width:26px;height:26px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.address-marker-popup-close:hover{border-color:var(--color-primary);color:var(--color-primary)}.address-marker-row{display:flex;flex-direction:column;gap:8px}.address-marker-label{font-size:12px;font-weight:700;color:var(--text-secondary)}.address-input-group{display:flex;gap:8px}.address-marker-input{flex:1;min-width:0;border:1px solid var(--border-soft);border-radius:4px;background:var(--bg-L1);color:var(--text-primary);height:32px;padding:0 10px}.address-marker-input:focus{outline:none;border-color:var(--color-primary)}.address-search-btn{border:1px solid var(--border-soft);background:var(--bg-L1);color:var(--text-secondary);border-radius:4px;min-width:62px;cursor:pointer}.address-search-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.address-search-status{font-size:12px;color:var(--text-muted)}.address-search-error{color:#ef5350}.address-search-results{max-height:128px;overflow:auto;border:1px solid var(--border-soft);border-radius:6px;background:var(--bg-L1);display:flex;flex-direction:column}.address-result-item{border:none;border-bottom:1px solid var(--border-soft);background:transparent;color:var(--text-secondary);text-align:left;padding:8px 10px;cursor:pointer;display:flex;flex-direction:column;gap:3px}.address-result-item:last-child{border-bottom:none}.address-result-item:hover{background:var(--bg-hover)}.address-result-item.selected{background:rgb(from var(--color-primary) r g b / .2);color:var(--text-primary)}.address-result-item small{color:var(--text-muted);font-size:11px}.address-resource-dropzone{border:1px dashed var(--border-soft);border-radius:6px;min-height:120px;max-height:260px;overflow-y:scroll;background:rgb(from var(--bg-L1) r g b / .7);padding:10px}.address-resource-dropzone.dragging{border-color:var(--color-primary);background:rgb(from var(--color-primary) r g b / .1)}.address-resource-placeholder{min-height:100px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;color:var(--text-muted);font-size:12px;text-align:center}.address-resource-table{width:100%;border-collapse:collapse;font-size:12px}.address-resource-table th,.address-resource-table td{border:1px solid var(--border-soft);padding:6px;text-align:center}.address-resource-table th{color:var(--text-secondary);font-weight:700;background:rgb(from var(--bg-L2) r g b / .8)}.address-resource-table td:first-child{text-align:left}.address-resource-amount-input{width:64px;height:26px;border:1px solid var(--border-soft);border-radius:4px;background:var(--bg-L1);color:var(--text-primary);text-align:center}.address-resource-amount-input:focus{outline:none;border-color:var(--color-primary)}.address-resource-remove-btn{border:1px solid var(--border-soft);background:var(--bg-L1);color:var(--text-muted);border-radius:4px;height:24px;cursor:pointer}.address-resource-remove-btn:hover{border-color:#ef5350;color:#ef5350}.address-submit-error{color:#ef5350;font-size:12px}.address-popup-actions{display:flex;justify-content:flex-end;gap:8px}.address-popup-cancel,.address-popup-submit{border:1px solid var(--border-soft);border-radius:4px;min-width:76px;height:32px;cursor:pointer;font-weight:600}.address-popup-cancel{background:var(--bg-L1);color:var(--text-secondary)}.address-popup-submit{background:rgb(from var(--color-primary) r g b / .88);border-color:var(--color-primary);color:#fff}.deploy-mode-indicator{position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:12;background-color:rgb(from var(--bg-L1) r g b / .5);border:1px solid var(--color-primary);border-radius:4px;padding:var(--spacing-sm) var(--spacing-md);font-size:13px;color:var(--text-primary);font-weight:600;text-align:center}.deploy-map-section{position:absolute;inset:0;overflow:hidden}.deploy-map-background{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:1;pointer-events:none}.deploy-map-grid-cell{position:relative;background:transparent;border:1px solid rgba(68,68,68,.3);transition:background-color .2s ease;display:flex;align-items:center;justify-content:center;cursor:default}.deploy-map-grid-cell.placement-mode{cursor:crosshair}.deploy-map-grid-cell.placement-mode:hover{background-color:#4a90e21a;border-color:#4a90e280}.deploy-map-marker-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5;cursor:pointer}.deploy-map-marker{width:40px;height:40px;display:flex;align-items:center;justify-content:center;position:relative}.deploy-map-marker:hover{transform:scale(1.2)}.deploy-marker-icon{width:40px;height:40px;object-fit:contain}.deploy-marker-popup{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#fffffffa;border-radius:6px;padding:10px 12px;min-width:120px;box-shadow:0 4px 12px #0000004d;z-index:10;white-space:nowrap;pointer-events:none}.deploy-marker-popup:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#fff}.deploy-popup-title{font-size:13px;font-weight:700;color:#333;text-align:center}.marker-resource-tooltip{box-shadow:0 4px 12px #0006;position:absolute;z-index:10;background-color:var(--bg-L3);color:var(--text-primary);padding:10px 14px;border-radius:6px;font-size:13px;max-width:280px;border:1px solid var(--border-soft);overflow:hidden;display:flex;flex-direction:column}.marker-resource-table{border-collapse:collapse}.marker-resource-tooltip-header{font-weight:700;font-size:14px;display:flex;justify-content:space-between;align-items:center;cursor:grab}.marker-resource-tooltip[data-dragging] .marker-resource-tooltip-header{cursor:grabbing}.marker-resource-tooltip-close{display:inline-flex;padding:0;border:none;background:none;cursor:pointer}.marker-resource-tooltip-edit{border:1px solid var(--border-soft);background:var(--bg-L1);color:var(--text-secondary);border-radius:4px;padding:2px 8px;margin-left:auto;margin-right:6px;cursor:pointer;font-size:12px}.marker-resource-tooltip-edit:hover{border-color:var(--color-primary);color:var(--color-primary)}.marker-resource-tooltip-header svg,.marker-resource-tooltip-close svg{cursor:pointer;opacity:.8;transition:opacity .2s ease}.marker-resource-tooltip-header svg:hover,.marker-resource-tooltip-close:hover svg{opacity:1}.marker-resource-table td{border:1px solid var(--border-strong);padding:0 6px;white-space:nowrap}.marker-resource-tooltip-address{border-bottom:1px solid var(--border-soft);font-size:12px;color:var(--text-secondary, #666)}.marker-resource-tooltip-address .marker-address-line{margin-top:2px;word-break:keep-all;white-space:nowrap}.marker-resource-tooltip-address .marker-address-loading{font-style:italic}.marker-resource-tooltip-address .marker-address-error{color:#c62828}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.rd-popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:12}.rd-popup-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:95%;max-width:720px;background:var(--bg-L3);z-index:13;display:flex;flex-direction:column}.rd-popup-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-L2);border-bottom:1px solid var(--border-soft)}.rd-popup-title{margin:0;font-size:14px;color:var(--text-primary)}.rd-popup-header-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.rd-popup-btn{background:var(--bg-L3);border:1px solid var(--border-soft);cursor:pointer;padding:var(--spacing-xs);color:var(--text-primary);display:flex;align-items:center;justify-content:center}.rd-popup-btn-download,.rd-popup-btn-print{background:var(--bg-L3);color:var(--text-primary)}.rd-popup-close{background:none;border:none;cursor:pointer;padding:var(--spacing-xs);color:var(--text-muted);display:flex;align-items:center;justify-content:center}.rd-popup-content{padding:var(--spacing-sm) var(--spacing-md)}.rd-popup-info-section{margin-bottom:var(--spacing-sm)}.rd-popup-info-item{margin-bottom:var(--spacing-xs);display:flex;gap:var(--spacing-sm)}.rd-popup-info-label{color:var(--text-primary);flex-shrink:0;min-width:70px;font-size:14px}.rd-popup-info-value{color:var(--text-secondary);font-size:14px}.rd-popup-deployment-section{margin-top:var(--spacing-sm)}.rd-popup-section-title{margin:0 0 var(--spacing-xs) 0;font-size:14px;color:var(--text-primary)}.rd-popup-deployment-point{margin-bottom:var(--spacing-sm)}.rd-popup-point-title{margin:0 0 var(--spacing-xs) 0;font-size:13px;color:var(--text-primary)}.rd-popup-table-container{display:flex;justify-content:center;margin-bottom:var(--spacing-sm)}.rd-popup-resource-table{width:90%;max-width:650px;border-collapse:collapse;background:var(--bg-L2)}.rd-popup-resource-table thead{background:var(--bg-L6)}.rd-popup-resource-table th{padding:var(--spacing-xs) var(--spacing-sm);text-align:center;color:var(--text-primary);border-bottom:1px solid var(--border-soft);font-size:12px}.rd-popup-resource-table td{padding:var(--spacing-xs) var(--spacing-sm);text-align:center;color:var(--text-secondary);border-bottom:1px solid var(--border-medium);font-size:12px}.rd-popup-resource-table tbody tr:last-child td{border-bottom:none}@media print{body *{visibility:hidden}.rd-popup-overlay,.rd-popup-header{display:none!important}.rd-popup-content,.rd-popup-content *{visibility:visible}.rd-popup-container{position:absolute!important;top:0!important;left:0!important;transform:none!important;width:100%!important;max-width:100%!important;margin:0!important;padding:0!important;box-shadow:none!important;background:#fff!important}.rd-popup-content{position:absolute!important;top:0!important;left:0!important;width:100%!important;padding:var(--spacing-xl)!important;background:#fff!important}.rd-popup-deployment-point{page-break-inside:avoid}.rd-popup-info-label,.rd-popup-info-value,.rd-popup-section-title,.rd-popup-point-title,.rd-popup-resource-table th,.rd-popup-resource-table td{color:#000!important}.rd-popup-resource-table{background:#fff!important}.rd-popup-resource-table thead,.rd-popup-resource-table th{background:#f0f0f0!important}}.equipment-main-content{grid-column:4 / 97;grid-row:1 / 49;background:var(--bg-L3);border:1px solid var(--border-soft);display:flex;flex-direction:column;overflow:hidden;padding:10px}.equipment-content-area{flex:1;overflow-y:auto;padding:10px}.info-input-container{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:1fr auto;height:100%;gap:var(--spacing-lg);padding:var(--spacing-md)}.info-input-card{overflow-y:auto;display:flex;flex-direction:column;min-height:0;border:1px solid var(--border-medium);border-radius:10px;padding:var(--spacing-lg);background:var(--bg-L3)}.info-input-card-location{display:flex;flex-direction:column}.info-input-card-location .image-upload-area{flex:1;min-height:120px}.info-input-bottom{grid-column:1 / -1;display:flex;justify-content:flex-end;align-items:center;padding:var(--spacing-md) var(--spacing-sm);gap:12px;border-top:1px solid var(--border-soft);margin-top:4px}.image-upload-area{flex:1;border:2px dashed var(--border-medium);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-top:12px;cursor:pointer;transition:border-color .2s ease,background .2s ease;overflow:hidden;position:relative;min-height:140px}.image-upload-area:hover{border-color:var(--color-primary);background:#4a90e21a}.image-upload-area.dragging{border-color:var(--color-primary);background:#4a90e233;border-width:3px}.upload-placeholder{color:var(--text-muted);text-align:center;font-size:14px;line-height:1.5}.upload-placeholder:first-of-type{font-weight:500;margin-bottom:4px}.image-preview-container{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:10px}.image-preview-grid{width:100%;height:100%;display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;padding:10px;overflow-y:auto;align-content:start}.image-preview-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:5px;padding:8px;border:1px solid var(--border-soft);border-radius:4px;background:var(--bg-L3);transition:all .3s ease}.image-preview-item:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #4a90e233}.image-preview{max-width:100%;max-height:120px;object-fit:contain;border-radius:4px}.image-filename{color:var(--text-tertiary);font-size:11px;text-align:center;word-break:break-all;padding:2px 5px;border-radius:4px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-remove-button{position:absolute;top:5px;right:5px;width:24px;height:24px;border-radius:50%;border:none;background:#ff0000b3;color:#fff;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1;padding:0}.image-remove-button:hover{background:#ff0000e6}.form-section{border-radius:6px}.info-input-card .section-header{padding:10px 0 12px;margin-bottom:4px;border-bottom:2px solid var(--border-medium)}.info-input-card .section-title{font-size:15px;font-weight:700;letter-spacing:-.02em;padding-bottom:0;margin:0}.checkbox-label{display:flex;align-items:center;gap:10px;color:var(--text-tertiary);font-size:14px;cursor:pointer;padding:4px 0}.checkbox-label span{line-height:1.4}.checkbox-label input[type=checkbox]{width:18px;height:18px;min-width:18px;cursor:pointer;accent-color:var(--color-primary)}.form-grid{display:flex;flex-direction:column;gap:18px;padding:var(--spacing-md) 0;margin-bottom:24px}.form-grid:last-of-type{margin-bottom:0}.form-row.coordinate-row{display:flex;align-items:center;gap:10px}.form-field{display:flex;align-items:center;gap:10px;min-height:44px;width:100%}.form-label{display:flex;align-items:center;color:var(--text-primary);font-size:14px;font-weight:600;background:none;padding:8px 10px 8px 0;white-space:nowrap;width:110px;flex:0 0 110px;letter-spacing:-.01em;line-height:1.35}.form-input{background:var(--bg-L2);border:1px solid var(--border-medium);color:var(--text-primary);padding:10px 12px;font-size:14px;line-height:1.4;border-radius:6px;transition:border-color .2s ease,background .2s ease;flex:1;min-width:0}.form-input:focus{outline:none;border-color:var(--color-primary);background:var(--bg-L1);box-shadow:0 0 0 2px #4a90e226}.form-input:disabled{background:var(--bg-L5);cursor:not-allowed;opacity:.6}.form-input::placeholder{color:#666}.input-with-icon{position:relative;display:flex;flex:1;align-items:center}.input-with-icon .form-input{flex:1;padding-right:40px}.input-icon{position:absolute;right:10px;font-size:20px!important;color:var(--text-muted);pointer-events:none}.file-upload-container{display:flex;align-items:center;gap:10px}.info-input-bottom .save-button{padding:10px 20px;font-size:14px;border-radius:6px;min-height:40px}.input-hint{color:var(--text-muted);font-size:12px;margin-top:4px;padding-left:4px}.radio-group{display:flex;gap:10px;flex-wrap:wrap}.radio-label-with-input{display:flex;gap:8px;align-items:center;padding:4px 0}.radio-label{margin:0!important;border-radius:6px}.radio-label .MuiFormControlLabel-label{color:var(--text-tertiary)!important;font-size:14px!important;font-family:inherit!important;line-height:1.4}.radio-label .Mui-checked+.MuiFormControlLabel-label{color:var(--color-primary)!important;font-weight:600!important}.radio-custom-input{background:var(--bg-L2);border:1px solid var(--border-soft);color:var(--text-tertiary);padding:8px 12px;font-size:13px;line-height:1.35;border-radius:6px;transition:border-color .2s ease,background .2s ease;max-width:150px}.radio-custom-input:focus{outline:none;border-color:var(--color-primary);background:var(--bg-L3)}.radio-custom-input:disabled{background:var(--bg-L5);cursor:not-allowed;opacity:.4;color:#555}.radio-custom-input::placeholder{color:#666}.coordinate-field{gap:6px;min-height:44px}.coordinate-label{padding:8px 6px;white-space:nowrap;width:auto;flex:0 0 auto;font-size:14px;font-weight:600;color:var(--text-primary)}.coordinate-input{flex:1;max-width:82px;padding:10px;border-radius:6px}.equipment-select{background-color:var(--bg-L3)!important;color:var(--text-tertiary)!important}.equipment-select .MuiOutlinedInput-notchedOutline{border-color:var(--border-soft)!important}.equipment-select:hover .MuiOutlinedInput-notchedOutline,.equipment-select.Mui-focused .MuiOutlinedInput-notchedOutline{border-color:var(--color-primary)!important}.equipment-select .MuiSelect-icon{color:var(--text-tertiary)!important}.equipment-status-content{display:flex;flex-direction:column;height:100%;overflow:hidden}.equipment-status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:0 4px}.equipment-status-title{color:var(--text-primary);font-size:18px;font-weight:600;margin:0}.equipment-status-search{position:relative;display:flex;align-items:center;gap:var(--spacing-sm);width:600px}.equipment-search-input{width:100%;padding:8px 40px 8px 12px;background:var(--bg-L2);border:1px solid var(--border-soft);border-radius:4px;color:var(--text-primary);font-size:14px;transition:all .3s ease;flex:2}.equipment-search-input:focus{outline:none;border-color:var(--color-primary)}.equipment-search-input::placeholder{color:var(--text-muted)}.equipment-search-icon{position:absolute;right:12px;color:var(--text-muted);pointer-events:none;font-size:20px!important}.common-table th.checkbox-column{width:50px;text-align:center}.common-table .no-data{text-align:center;padding:40px;color:var(--text-muted);font-size:14px}.equipment-action-button{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px 8px;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease;border-radius:4px}.equipment-action-button:hover{background-color:#4a90e21a;color:var(--color-primary)}.equipment-action-button.download-button{color:var(--color-primary);font-size:13px;padding:4px 12px}.equipment-action-button.download-button:hover{background-color:#4a90e226}.history-info{position:absolute;inset:0;display:grid;grid-template-columns:280px 1fr;gap:0;background-color:var(--bg-L3);overflow:hidden;border:1px solid var(--border-soft)}.history-side{background:var(--bg-L4);border-right:1px solid var(--border-soft);display:flex;flex-direction:column;height:100%;overflow:hidden}.side-header{padding:var(--spacing-xl) var(--spacing-lg);border-bottom:1px solid var(--border-soft)}.side-title{color:var(--text-primary);font-size:20px;font-weight:700;margin:0;text-align:center}.side-menu{flex:1;overflow-y:auto;padding:8px 0}.history-menu-item{border-bottom:1px solid var(--border-soft)}.history-menu-item-header{display:flex;justify-content:space-between;align-items:center;padding:14px var(--spacing-lg);cursor:pointer;transition:background-color .2s;-webkit-user-select:none;user-select:none;background:var(--bg-L2)}.history-menu-item-header:hover{background-color:var(--bg-hover)}.history-menu-item-title{color:var(--text-primary);font-size:15px;font-weight:600}.history-expand-icon-wrap{display:inline-flex;align-items:center;justify-content:center;transition:transform .25s ease}.history-expand-icon-wrap.expanded{transform:rotate(0)}.history-expand-icon-wrap:not(.expanded){transform:rotate(180deg)}.history-expand-icon{color:var(--text-muted);font-size:20px;transition:color .2s}.history-submenu-wrapper{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s ease-out;overflow:hidden}.history-submenu-wrapper.expanded{grid-template-rows:1fr}.history-submenu-inner{min-height:0;overflow:hidden}.history-submenu-item{padding:10px 16px 10px 32px;color:var(--text-tertiary);background:var(--bg-L3);font-size:14px;cursor:pointer;transition:all .2s;border-left:3px solid transparent;display:flex;align-items:center;gap:8px}.history-submenu-item:hover{background-color:var(--bg-hover);color:var(--text-primary);border-left-color:var(--color-primary)}.history-submenu-item.active{background-color:var(--bg-L5);color:var(--color-primary);font-weight:600;border-left-color:var(--color-primary)}.history-content{background:var(--bg-L4);display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm);overflow-y:auto;z-index:3}.content-placeholder{width:100%;max-width:800px;text-align:center}.placeholder-content{background:var(--bg-L6);border:1px solid var(--border-soft);padding:60px 40px}.placeholder-title{color:var(--text-primary);font-size:24px;font-weight:700;margin:0 0 var(--spacing-lg) 0}.measurement-view{width:100%;height:100%;display:flex;flex-direction:column;gap:16px;padding:8px;overflow:hidden}.measurement-chart-section{flex:1;min-height:0;display:flex;flex-direction:column;background:var(--bg-L3);border:1px solid var(--border-soft);border-radius:8px;padding:var(--spacing-lg)}.measurement-history-section{flex:1;min-height:0;background:var(--bg-L3);border:1px solid var(--border-soft);border-radius:8px;padding:var(--spacing-lg);display:flex;flex-direction:column;overflow:hidden}.history-table-container{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.history-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.history-table-title{color:var(--text-primary);font-size:20px;font-weight:700;margin:0}.history-download-button{padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--bg-L2);border:1px solid var(--border-medium);border-radius:4px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.history-download-button:hover{background-color:var(--bg-hover);border-color:var(--color-primary)}.history-placeholder{text-align:center}.history-placeholder-title{color:var(--text-primary);font-size:20px;font-weight:700;margin:0 0 var(--spacing-md) 0}.history-placeholder-text{color:var(--text-muted);font-size:14px;margin:0}.settings-page{width:100%;height:100%;display:flex;flex-direction:column;background-color:var(--bg-L3);color:var(--text-secondary)}.settings-page-header{padding:24px 32px;border-bottom:2px solid var(--color-primary);background-color:#3a3a3a66}.settings-page-title{margin:0;font-size:28px;font-weight:700;color:var(--text-primary);letter-spacing:.5px}.settings-page-content{flex:1;padding:32px;overflow-y:auto}.settings-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;gap:16px}.settings-placeholder p{margin:0;font-size:18px;color:var(--text-tertiary)}.settings-placeholder-sub{font-size:14px;color:var(--text-muted)}.grid-container{position:absolute;inset:0;display:grid;grid-template-columns:var(--grid-columns);grid-template-rows:var(--grid-rows);gap:var(--spacing-sm);padding:var(--spacing-sm);background-color:var(--bg-L3);box-sizing:border-box;z-index:3}.grid-layout{display:grid;grid-template-columns:var(--grid-columns);grid-template-rows:var(--grid-rows);height:100%;position:relative}.grid-section{background:var(--bg-L3);border:1px solid var(--border-soft);padding:var(--spacing-md);display:flex;flex-direction:column;border-radius:var(--radius-lg)}.grid-section--flush{padding:0}.grid-section-title{color:var(--text-primary);font-size:16px;font-weight:700;margin:0 0 var(--spacing-sm) 0;padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-soft)}.grid-section-content{flex:1;width:100%;height:100%;color:var(--text-tertiary);display:grid;grid-template-columns:repeat(20,1fr);grid-template-rows:repeat(20,1fr)}.tmp-img{grid-column:1 / -1;grid-row:1 / -1}.sidebar-section{background:var(--bg-L3);grid-column:1 / 4;grid-row:1 / 49;display:flex;flex-direction:column;position:relative;z-index:12}.sidebar-menu{display:flex;flex-direction:column;height:100%}.sidebar-menu-item{display:flex;flex-direction:column;align-items:center;background:var(--bg-L3);color:var(--text-secondary);border:1px solid var(--border-soft);font-size:10px;font-weight:500;cursor:pointer;transition:all .3s ease;padding:4px 2px}.sidebar-menu-item:hover{background:#4a90e24d;border-color:var(--color-primary)}.sidebar-menu-item.active{background:#4a90e280;border-color:var(--color-primary);color:var(--text-primary)}.sidebar-icon{font-size:20px!important}.sidebar-text{margin-top:var(--spacing-xs);font-size:12px;text-align:center}.content-section{position:relative;grid-column:4 / -1;grid-row:1 / -1;min-height:0;height:100%;background:var(--bg-L3);border-radius:var(--radius-lg);overflow:hidden}.sensor-settings-layout{display:grid;grid-template-columns:300px 1fr 400px;gap:0;height:100%;overflow:hidden}.left-sidebar.sensor-list-panel{display:flex;flex-direction:column;background:var(--bg-L4);border-right:1px solid var(--border-soft);height:100%;overflow:hidden}.left-sidebar .panel-header,.right-sidebar .panel-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-soft);background:var(--bg-L5)}.left-sidebar .panel-header h3,.right-sidebar .panel-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.sensor-rows-container{flex:1;overflow-y:auto;padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-sm)}.sensor-row{background:var(--bg-L3);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:var(--spacing-md);cursor:pointer;transition:all .2s}.sensor-row:hover{background:var(--bg-hover);border-color:var(--color-primary);box-shadow:0 2px 8px #0000001a}.sensor-row.selected{background:#4a90e226;border-color:var(--color-primary);box-shadow:0 2px 8px #4a90e233}.sensor-row-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.sensor-info{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.sensor-icon{width:32px;height:32px;object-fit:contain}.sensor-details{display:flex;flex-direction:column;gap:2px}.sensor-name{font-size:14px;font-weight:600;color:var(--text-primary)}.sensor-type{font-size:12px;color:var(--text-tertiary)}.sensor-row-footer{display:flex;gap:var(--spacing-lg);padding-top:var(--spacing-sm);border-top:1px solid var(--border-soft)}.status-group{display:flex;align-items:center;gap:var(--spacing-sm)}.status-label{font-size:12px;color:var(--text-secondary)}.status-indicator{width:12px;height:12px;border-radius:50%;display:inline-block}.map-container{position:relative;height:100%;overflow:hidden;background:var(--bg-L2)}.right-sidebar.settings-panel{display:flex;flex-direction:column;background:var(--bg-L4);border-left:1px solid var(--border-soft);height:100%;overflow:hidden}.settings-tabs{flex-shrink:0;background:var(--bg-L5)}.tab-panel{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:var(--spacing-lg);gap:var(--spacing-lg)}.selected-sensor-info{padding:var(--spacing-md);background:var(--bg-L3);border-radius:var(--radius-md);border:1px solid var(--border-soft)}.selected-sensor-info .info-row{display:flex;align-items:center;gap:var(--spacing-sm)}.selected-sensor-info .label{font-size:13px;color:var(--text-secondary);font-weight:500}.selected-sensor-info .value{font-size:14px;color:var(--text-primary);font-weight:600}.setting-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.section-header{display:flex;align-items:center;justify-content:space-between}.setting-field{display:flex;flex-direction:column;gap:var(--spacing-sm)}.setting-field label{font-size:13px;color:var(--text-secondary);font-weight:500}.setting-field-horizontal{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.setting-field-horizontal label{font-size:13px;color:var(--text-secondary);font-weight:500;text-wrap:nowrap}.additional-settings-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.additional-setting-item{background:var(--bg-L3);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:var(--spacing-md)}.item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-soft)}.item-number{font-size:13px;font-weight:600;color:var(--text-primary)}.remove-item-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s}.remove-item-btn:hover{background:#f443361a;color:#f44336}.item-content-container{display:flex;flex-direction:column;gap:var(--spacing-sm)}.item-content{display:flex;justify-content:center;gap:var(--spacing-md)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center;gap:var(--spacing-md)}.empty-state p{margin:0;color:var(--text-tertiary);font-size:13px}.empty-state-large{display:flex;align-items:center;justify-content:center;height:100%;padding:var(--spacing-xl)}.empty-state-large p{margin:0;color:var(--text-tertiary);font-size:14px}.add-setting-btn-small{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);margin-bottom:var(--spacing-xs);background:var(--bg-L6);border:1px solid var(--border-soft);border-radius:var(--radius-md);color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.add-setting-btn-small:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.add-setting-btn-large{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);background:var(--bg-L6);border:1px dashed var(--border-soft);border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.add-setting-btn-large:hover{background:var(--bg-hover);border-color:var(--color-primary);color:var(--color-primary)}.date-input-field{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-soft);border-radius:var(--radius-md);font-size:13px;color:var(--text-primary);background-color:var(--bg-L3);cursor:pointer;width:100%;transition:all .2s}.date-input-field:focus{outline:none;border-color:var(--color-primary);background-color:var(--bg-L2)}.status-cards-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.status-card{flex:0 0 auto;width:100%;display:flex;flex-direction:column;border:1px solid var(--border-soft);overflow:hidden;border-radius:var(--radius-lg);background-color:var(--bg-L3);transition:all .2s}.status-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-xs) var(--spacing-sm);font-weight:600;font-size:16px;color:var(--text-primary);background-color:var(--bg-L2);cursor:pointer;-webkit-user-select:none;user-select:none}.status-card-header:hover{filter:brightness(1.05)}.status-card-header-leading{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:0}.status-card-header-color{width:14px;height:14px;border-radius:3px;flex-shrink:0}.status-card-header-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-card-header svg{font-size:24px;opacity:.9}.status-card-body{padding:var(--spacing-sm);display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:var(--spacing-md);flex:1;width:100%}.status-card-footer{display:flex;justify-content:space-between}.status-setting-section{display:flex;flex-direction:column;gap:var(--spacing-md);width:100%}.status-group-section{display:flex;flex-direction:column;gap:var(--spacing-xs)}.status-setting-split{display:flex;flex-direction:column;gap:var(--spacing-sm);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:var(--spacing-sm)}.status-setting-split--section-off{opacity:.55}.status-reception-rate-row--off>*:not(:first-child){opacity:.55}.status-setting-split-title{text-align:left;font-size:16px;font-weight:600;padding:0}.status-setting-card-title-row{display:flex;align-items:center;gap:var(--spacing-sm)}.status-time-row{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.status-time-row .status-input{min-width:3rem}.status-reception-rate-row{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.status-input-inline{flex:0 1 5rem;min-width:3rem}.status-setting-suffix{font-size:14px;color:var(--text-secondary);white-space:nowrap}.card-status-label.card-status-label-inline{flex:0 0 auto;flex-direction:row;align-items:center;justify-content:flex-start;min-width:4.5rem}.status-condition-row{width:100%}.status-condition-group{width:100%;justify-content:flex-start}.status-input-group{display:flex;align-items:center;gap:var(--spacing-sm)}.card-status-label{display:flex;flex-direction:column;align-items:center;justify-content:space-between;flex:1;color:var(--text-secondary);font-size:14px;font-weight:700}.status-select{color:var(--text-primary)!important;font-size:13px!important;width:100%!important}.status-input{flex:.2;width:100%;background:var(--bg-L2);border:1px solid var(--border-soft);font-size:14px;text-align:start;color:var(--text-primary);padding:var(--spacing-xs);transition:all .2s}.status-input:focus{outline:none;border-color:var(--color-primary);background-color:var(--bg-L1)}.status-input-row{display:flex;gap:var(--spacing-sm)}.panel-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-soft);background:var(--bg-L5);margin:0 calc(-1 * var(--spacing-lg)) calc(-1 * var(--spacing-lg))}.status-action-button{padding:var(--spacing-xs) 24px;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.modify-button{background-color:#757575;color:#fff}.modify-button:hover{background-color:var(--bg-hover)}.status-action-button.save-button{background-color:var(--color-primary);color:var(--text-filled-btn)}.status-action-button.save-button:hover{background-color:var(--color-primary-hover)}
