:root{--bg-color: #F3F3F3;--primary-color: #FFE000;--sidebar-bg: #FFFFFF;--accent-color: #00AB84;--text-main: #333333;--text-primary: rgba(0, 0, 0, .9);--text-muted: #4E5969;--border-color: #E7E7E7;--sidebar-width: 256px;--topbar-height: 56px;--transition-speed: .25s}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{display:flex;min-height:100vh}button{cursor:pointer;border:none;background:none;font-family:inherit}ul{list-style:none}.custom-dialog-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0006;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.custom-dialog-container{padding:16px;background:#fff;box-shadow:0 8px 10px -5px #00000014,0 16px 24px 2px #0000000a,0 6px 30px 5px #0000000d;border-radius:6px;border:.5px solid #DCDCDC;display:flex;flex-direction:column;justify-content:center;align-items:flex-end;gap:16px;min-width:400px;max-width:470px}.custom-dialog-content{width:100%;display:flex;justify-content:flex-start;align-items:flex-start;gap:8px}.custom-dialog-icon-wrapper{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.custom-dialog-icon{width:24px;height:24px}.custom-dialog-text-wrapper{flex:1;display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start;gap:8px}.custom-dialog-header{align-self:stretch;display:flex;justify-content:flex-start;align-items:flex-start;gap:24px}.custom-dialog-title{flex:1;color:#000000e6;font-size:16px;font-family:PingFang SC,sans-serif;font-weight:600;line-height:24px;word-wrap:break-word}.custom-dialog-body{align-self:stretch;color:#0009;font-size:14px;font-family:PingFang SC,sans-serif;font-weight:400;line-height:22px;word-wrap:break-word}.custom-dialog-footer{display:flex;justify-content:flex-start;align-items:flex-start;gap:8px}.custom-dialog-btn{padding:5px 16px;overflow:hidden;border-radius:3px;justify-content:center;align-items:center;display:flex;cursor:pointer;font-size:14px;font-family:PingFang SC,sans-serif;font-weight:400;line-height:22px;transition:all .2s}.custom-dialog-btn.cancel{color:#000000e6}.custom-dialog-btn.cancel:hover{background:#0000000d}.custom-dialog-btn.confirm{color:#0052d9}.custom-dialog-btn.confirm:hover{background:#0052d90d}.graphic-page{width:100%;height:100%;display:flex;flex-direction:column}.modal-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-header-content{display:flex;align-items:center;gap:32px;flex:1}.modal-close-btn{cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.modal-content-area{padding:0 24px 24px;max-height:400px;overflow-y:auto}.modal-footer{height:72px;padding:0 24px;display:flex;justify-content:center;align-items:center;gap:24px;border-top:1px solid #E7E7E7;background:#fff}.settings-drawer{width:1440px;max-width:100vw;height:458px;position:fixed;bottom:0;left:50%;transform:translate(-50%);background:#fff;overflow:hidden;box-shadow:0 -4px 20px #0000001a;z-index:3001}.drawer-header-title{left:24px;top:34px;position:absolute}.drawer-header-title span{color:#1d1d1b;font-size:22px;font-weight:700}.drawer-close-btn{width:40px;height:40px;right:24px;top:24px;position:absolute;cursor:pointer;display:flex;align-items:center;justify-content:center}.auto-scale-section{height:56px;padding:12px 6px;left:24px;top:82px;position:absolute;display:flex;align-items:center;gap:6px;cursor:pointer}.checkbox-rect{width:24px;height:24px;border-radius:4.5px;display:flex;align-items:center;justify-content:center;transition:background .2s}.range-inputs-container{display:flex;gap:24px;position:absolute;left:251px;top:86px;align-items:center}.range-field{display:flex;align-items:center;gap:8px}.range-label{color:#666;font-size:18px;text-transform:capitalize}.range-input-box{width:159px;height:48px;background:#f3f3f3;border-radius:4px;border:1px solid #D9D9D9}.range-input-box input{width:100%;height:100%;background:transparent;border:none;padding:0 12px;font-size:20px;outline:none}.color-section{left:24px;top:166px;position:absolute}.color-section-label{font-size:22px;font-weight:700;margin-bottom:20px;color:#1d1d1b}.color-blocks-grid{display:flex;flex-direction:column;gap:12px}.color-blocks-row{display:flex;gap:6px}.color-swatch{width:72px;height:48px;border-radius:12px;cursor:pointer;position:relative;transition:transform .1s}.selected-color-indicator{width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;left:4px;top:4px;display:flex;align-items:center;justify-content:center}.drawer-footer-bar{width:100%;height:72px;position:absolute;bottom:0;background:#fff;border-top:1px solid #E7E7E7;display:flex;align-items:center;justify-content:flex-end;padding-right:24px;gap:8px}.btn-drawer-cancel{padding:8px 24px;background:#e7e7e7;border-radius:3px;cursor:pointer;color:#000000e6;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;border:none}.btn-drawer-confirm{padding:8px 24px;background:#00ab84;border-radius:3px;cursor:pointer;color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;border:none}.chart-name-dialog{width:440px;height:282px;background:#fff;padding:24px;border-radius:8px;display:flex;flex-direction:column;gap:24px}.chart-name-modal-title{text-align:center;font-size:16px;font-weight:700}.chart-name-input-area{display:flex;flex-direction:column;gap:10px}.input-with-label{display:flex;align-items:center;gap:12px}.input-with-label label{font-size:14px;color:#000000e6;width:80px;text-align:right}.input-wrapper-bordered{flex:1;height:32px;border:1px solid #DCDCDC;border-radius:3px;padding:0 8px;display:flex;align-items:center}.input-wrapper-bordered input{flex:1;border:none;outline:none;font-size:14px;background:transparent}.input-hint{color:#0006;font-size:12px;padding-left:92px}.header-controls-container{display:flex;align-items:center;gap:12.8px}.header-controls-container.mini{gap:8px}.btn-graphic-control{width:128px;height:32px;padding:0 12px;background:#ffe000;border-radius:3.2px;border:none;display:flex;align-items:center;gap:3px;justify-content:center;cursor:pointer;white-space:nowrap}.btn-graphic-control.mini{width:auto;height:22px;padding:0 6px}.btn-icon-square{width:32px;height:32px;background:#ffe000;border-radius:3.2px;display:flex;align-items:center;justify-content:center;cursor:pointer}.btn-icon-square.mini{width:22px;height:22px}.label-text{font-size:14px;font-family:Arial;font-weight:700;color:#191919}.label-text.mini{font-size:10px}.edit-icon-wrapper{width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer}.graphic-view-box{display:flex;flex-direction:column;flex:1;background:#fff;overflow:hidden}.graphic-view-box .channel-bar{padding:0 68px;height:72px;display:flex;align-items:center;border-bottom:1px solid #E7E7E7}.graphic-view-box.mini .channel-bar{padding:0 28px;height:40px}.channel-tabs-row{display:flex;gap:4px;flex:1;overflow:hidden}.channel-tab-item{width:166px;min-width:166px;height:72px;border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 4px;cursor:pointer;transition:all .2s}.channel-tab-item.mini{width:83px;min-width:83px;height:32px}.channel-tab-item.empty{flex-direction:row;background:transparent;border:1px dashed #E7E7E7;gap:4px}.channel-tab-item.filled{border:1px solid #E7E7E7}.channel-tab-name{font-weight:700;width:100%;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chart-section{flex:1;display:flex;padding:30px 24px}.chart-section.mini{padding:20px 12px}.y-axis-container{display:flex;flex-direction:column;height:100%}.y-axis-labels{flex:1;display:flex;flex-direction:column;justify-content:space-between;width:48px;padding-right:2px}.graphic-view-box.mini .y-axis-labels{width:38px}.y-axis-spacer{height:40px}.graphic-view-box.mini .y-axis-spacer{height:24px}.y-axis-item{display:flex;align-items:center;justify-content:flex-end;gap:4px;width:100%}.axis-tick{background:#1d1d1b;flex-shrink:0}.y-axis-item .axis-tick{width:6px;height:1px}.graphic-view-box.mini .y-axis-item .axis-tick{width:4px}.x-axis-item .axis-tick{width:1px;height:6px}.graphic-view-box.mini .x-axis-item .axis-tick{height:4px}.grid-workspace{flex:1;border-left:1px solid #1D1D1B;border-bottom:1px solid #1D1D1B;border-right:none;border-top:none;position:relative;background-image:linear-gradient(to right,#f0f0f0 1px,transparent 1px),linear-gradient(to bottom,#f0f0f0 1px,transparent 1px)}.x-axis-labels{height:40px;display:flex;justify-content:space-between;padding-left:2px}.graphic-view-box.mini .x-axis-labels{height:24px}.x-axis-item{display:flex;flex-direction:column;align-items:center;width:1px;overflow:visible}.x-axis-item span{white-space:nowrap}.graphic-grid-layout{width:100%;height:100%;display:grid;grid-template-columns:repeat(auto-fill,560px);gap:24px;overflow-y:auto;padding:2px}.graphic-mini-card{width:560px;height:375px;background:#fff;border-radius:8px;box-shadow:0 2px 12px #00000014;display:flex;flex-direction:column;overflow:hidden;position:relative}.mini-chart-wrapper{flex:1;display:flex;flex-direction:column;overflow:hidden;cursor:pointer}.card-top-header{height:48px;border-bottom:1px solid #E7E7E7;display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0}.custom-checkbox{width:18px;height:18px;border:1.5px solid #DCDCDC;border-radius:2px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;background:#fff;position:relative}.custom-checkbox:hover{border-color:#00ab84}.custom-checkbox.checked{background:#00ab84;border-color:#00ab84}.custom-checkbox.checked:after{content:"";width:10px;height:5px;border-left:2px solid white;border-bottom:2px solid white;transform:rotate(-45deg) translateY(-1px)}.btn-graphic-remove{width:32px;height:32px;background:#ffe000;border:none;border-radius:3.2px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#191919;transition:background .2s,color .2s;padding:0;box-sizing:border-box}.btn-graphic-remove:hover{background:#ff4d4f;color:#fff}.btn-graphic-remove.mini{width:22px;height:22px}.logger-settings-page{display:flex!important;flex-direction:column!important;align-items:stretch!important;justify-content:flex-start!important;width:100%!important;height:100%!important;overflow:hidden}.logger-header{height:auto;min-height:80px;padding:14px 24px;display:flex;align-items:flex-start;justify-content:space-between;border-bottom:1px solid #F0F0F0;flex-shrink:0}.logger-title-section{display:flex;flex-direction:column;gap:4px}.logger-title{font-size:18px;font-weight:700;color:#191919;font-family:Arial,sans-serif;margin:0;line-height:1.5}.logger-subtitle{font-size:14px;color:#86909c;font-family:Arial,sans-serif;margin:0;line-height:22px}.btn-create-logger{display:flex;align-items:center;gap:8px;background:#00ab84;color:#fff;border:none;border-radius:3.2px;padding:6px 16px;font-family:Arial,sans-serif;font-size:14px;cursor:pointer;transition:background .2s;margin-top:4px;flex-shrink:0}.btn-create-logger:hover{background:#009070}.logger-content{flex:1;padding:24px;display:flex;flex-direction:column;gap:24px;overflow-y:auto}.logger-fields-card{width:100%;padding:20px 32px;border-radius:8px;border:1px solid #E7E7E7;background:#fff;display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-shrink:0;box-sizing:border-box}.logger-fields-column{display:flex;flex-direction:column;gap:20px;flex:1}.logger-field-item{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:12px}.logger-field-item label{color:#0006;font-size:14px;font-family:PingFang SC,sans-serif;white-space:nowrap;flex-shrink:0}.logger-field-item select,.logger-field-item input{color:#000000e6;font-size:14px;font-family:PingFang SC,sans-serif;font-weight:400;text-align:right;background:transparent;border:none;border-bottom:1px solid #E7E7E7;outline:none;padding:2px 4px;min-width:0;width:180px;cursor:pointer}.logger-display-value{color:#000000e6;font-size:14px;font-family:PingFang SC,sans-serif;font-weight:500;text-align:right;padding:2px 4px;min-width:0;width:180px;border-bottom:1px solid transparent}.logger-field-item select:focus,.logger-field-item input:focus{border-bottom-color:#00ab84}.logger-table-container{flex:1;border:1px solid #E7E7E7;border-radius:4px;overflow-y:auto;max-height:500px}.logger-table th{background:#f3f3f3;text-align:left;padding:12px 16px;font-size:14px;font-weight:600;color:#191919;border-bottom:1px solid #E7E7E7}.logger-table td{padding:12px 16px;font-size:14px;color:#000000e6;border-bottom:1px solid #F0F0F0}.logger-table tr:last-child td{border-bottom:none}.logger-table tr:hover{background:#00000005}.logger-table .td-location{color:#86909c}.logger-table-header{display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.logger-table-title{font-size:15px;font-weight:600;color:#191919;font-family:PingFang SC,sans-serif}.btn-select-channels{padding:4px 12px;background:#00ab84;border:none;border-radius:3px;color:#ffffffe6;font-size:12px;font-family:PingFang SC,sans-serif;cursor:pointer;transition:background .2s}.btn-select-channels:hover{background:#009070}.logger-empty-row td{text-align:center;padding:48px 16px!important;color:#00000059!important;font-size:14px}.logger-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:200}.logger-drawer{position:fixed;top:0;right:0;width:568px;height:100vh;background:#fff;z-index:201;display:flex;flex-direction:column;box-shadow:-4px 0 24px #0000001f;transition:transform .3s ease}.logger-drawer.open{transform:translate(0)}.logger-drawer.closed{transform:translate(100%)}.btn-header-edit{display:flex;align-items:center;gap:8px;background:#00ab84;color:#fff;border:none;border-radius:4px;padding:8px 18px;font-family:PingFang SC,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease-in-out;margin-top:4px;box-shadow:0 2px 6px #00ab8426}.btn-header-edit:hover{background:#009070;box-shadow:0 4px 12px #00ab8440;transform:translateY(-1px)}.btn-header-edit:active{transform:translateY(0)}.header-actions-container{display:flex;align-items:center;gap:12px;margin-top:4px}.btn-header-cancel{display:flex;align-items:center;background:transparent;color:#4e5969;border:1px solid #E7E7E7;border-radius:4px;padding:8px 18px;font-family:PingFang SC,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease-in-out}.btn-header-cancel:hover{background:#f3f3f3;color:#191919;border-color:#c9cdd4}.btn-header-save{display:flex;align-items:center;background:#00ab84;color:#fff;border:none;border-radius:4px;padding:8px 18px;font-family:PingFang SC,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease-in-out;box-shadow:0 2px 6px #00ab8426}.btn-header-save:hover{background:#009070;box-shadow:0 4px 12px #00ab8440;transform:translateY(-1px)}.btn-header-save:active{transform:translateY(0)}.suto-sensor-page{display:flex!important;flex-direction:column!important;padding:0!important;align-items:stretch!important;justify-content:flex-start!important;overflow:hidden;height:100%}.suto-header{height:68px;padding:0 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #F0F0F0;flex-shrink:0}.suto-title{margin:0;font-size:18px;font-family:Arial,sans-serif;font-weight:700;color:#191919;line-height:40px}.add-sensor-btn{display:flex;align-items:center;gap:6px;height:32px;padding:0 16px;background:#00ab84;border:none;border-radius:3.2px;color:#fff;font-family:Arial,sans-serif;font-size:14px;font-weight:400;cursor:pointer;transition:background .2s}.add-sensor-btn:hover{background:#009070}.add-sensor-btn svg{width:16px;height:16px}.suto-body{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:0 24px}.suto-table-container{margin-top:8px;flex:1;overflow-y:auto}.suto-table{width:100%;border-collapse:collapse;table-layout:fixed}.suto-table th{background:#f3f3f3;text-align:left;padding:16px 24px;font-size:14px;font-family:PingFang SC,sans-serif;font-weight:600;color:#191919;border-bottom:1px solid #E7E7E7}.suto-table td{padding:16px 24px;font-size:14px;color:#191919;border-bottom:1px solid #E7E7E7;word-wrap:break-word}.suto-table tr:hover td{background:#00000005}.btn-icon-img{background:transparent;border:none;padding:0;width:32px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.btn-icon-img:hover{opacity:.8}.col-sensor,.col-description{width:258px}.col-address,.col-sn{width:210px}.col-operate{width:152px}.suto-empty-container{display:flex;align-items:center;justify-content:center;margin-top:130px;color:#4e5969;font-size:14px;font-family:Arial,sans-serif;line-height:22px;text-align:center}.suto-footer{height:56px;border-top:1px solid #E7E7E7;display:flex;align-items:center;justify-content:flex-end;padding:0 24px;gap:24px;flex-shrink:0}.pagination-info{display:flex;align-items:center;gap:8px;color:#616161;font-size:16px;font-family:Roboto,sans-serif}.items-per-page{display:flex;align-items:center;gap:8px;border-bottom:1px solid #616161;cursor:pointer}.page-counter{height:32px;padding:0 16px;background:#fff;border:1px solid #DEDEDE;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:12px;color:#616161}.pagination-controls{display:flex;align-items:center;gap:8px}.page-btn{width:32px;height:32px;background:#fff;border:1px solid #DEDEDE;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.page-btn:first-child{border-top-left-radius:16px;border-bottom-left-radius:16px}.page-btn:last-child{border-top-right-radius:16px;border-bottom-right-radius:16px}.page-btn:hover{background:#f5f5f5}.page-btn svg{width:16px;height:16px;color:#a2a2a2}.alarm-config-table th,.alarm-config-table td{padding:8px 12px}.alarm-inline-input{width:100%;height:32px;background:#f3f3f3;border:1px solid #D9D9D9;border-radius:4px;padding:0 4px;font-size:14px;color:#191919;outline:none;box-sizing:border-box}.alarm-inline-input[type=number]::-webkit-outer-spin-button,.alarm-inline-input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.alarm-inline-input[type=number]{-moz-appearance:textfield}.alarm-inline-input:focus{border-color:#00ab84;background:#fff}.alarm-switch{width:32px;height:16px;background:#e7e7e7;border-radius:8px;position:relative;cursor:pointer;transition:background .3s;display:inline-block;vertical-align:middle}.alarm-switch.on{background:#00ab84}.alarm-switch .switch-knob{width:12px;height:12px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:left .3s;box-shadow:0 1px 3px #0003}.alarm-switch.on .switch-knob{left:18px}.alarm-config-table select.alarm-inline-input{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.edit-channel-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer}.edit-channel-close:hover{opacity:.7}.edit-form-input-wrapper.active{border:1px solid #00AB84;outline:1px solid #00AB84}.edit-form-select{width:253px;height:32px;padding:0 8px;border:1px solid #D4D4D8;border-radius:3px;display:flex;align-items:center;justify-content:space-between;font-size:14px;color:#000000e6;cursor:pointer;background:#fff}.edit-form-item.disabled{opacity:.6}.edit-form-item.disabled .edit-form-input-wrapper{background-color:#f5f5f5}.edit-form-item.disabled .edit-form-input{background-color:transparent;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.config-modal{width:1136px;height:550px;background:#fff;border-radius:8px;position:relative;display:flex;flex-direction:column;box-shadow:0 12px 48px #00000026;overflow:hidden}.config-header{height:64px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #F0F0F0;flex-shrink:0}.config-title{font-size:18px;font-weight:700;color:#191919;font-family:Arial,sans-serif}.close-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer}.close-btn:hover{opacity:.7}.config-warning{padding:8px 24px;color:#f97316;font-size:14px;font-family:Arial,sans-serif;line-height:20px}.config-content{flex:1;display:flex;padding:0 24px;gap:24px;overflow:hidden}.config-left{width:360px;display:flex;flex-direction:column;gap:16px}.form-item{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:8px}.form-label{flex:1;font-size:14px;color:#000000e6;font-family:PingFang SC,sans-serif}.form-control{width:253px;height:32px;padding:5px 8px;border:1px solid #D4D4D8;border-radius:3px;font-size:14px;color:#000000e6;display:flex;align-items:center;justify-content:space-between;background:#fff;cursor:pointer}.form-control-wrapper{position:relative;width:253px}.form-select-hidden{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2}.form-control.disabled{background:#f5f5f5;cursor:not-allowed}.form-input{width:253px;height:32px;padding:5px 8px;border:1px solid #D4D4D8;border-radius:3px;font-size:14px;outline:none}.form-input::placeholder{color:#a1a1aa}.config-divider{width:1px;background:#e5e5e5;height:100%}.config-right{flex:1;display:flex;flex-direction:column;overflow:hidden}.config-table-container{flex:1;overflow-y:auto;border:1px solid #F0F0F0;border-radius:4px}.config-table{width:100%;border-collapse:collapse}.config-table th{background:#f4f4f5;text-align:left;padding:16px;font-size:14px;font-weight:600;color:#191919;border-bottom:1px solid #E5E5E5}.config-table td{padding:12px 16px;font-size:14px;color:#000000e6;border-bottom:1px solid #E5E5E5}.checkbox-cell{width:56px;text-align:center}.checkbox-custom{width:16px;height:16px;border-radius:3px;border:1px solid #00AB84;display:flex;align-items:center;justify-content:center;cursor:pointer}.checkbox-custom.checked{background:#00ab84}.checkbox-custom svg{width:10px;height:10px;color:#fff}.checkbox-custom.indeterminate{background:#00ab84}.checkbox-custom.indeterminate:after{content:"";width:8px;height:2px;background:#fff;border-radius:1px}.col-channel{width:240px}.col-unit{width:176px}.col-resolution{width:128px}.col-operate{width:112px}.config-footer{height:64px;padding:0 24px;display:flex;align-items:center;justify-content:flex-end;gap:24px;border-top:1px solid #F0F0F0;flex-shrink:0}.btn-cancel{padding:5px 16px;background:#e5e5e5;border-radius:3px;font-size:14px;color:#000000e6;border:none;cursor:pointer}.btn-confirm{padding:5px 16px;background:#00ab84;border-radius:3px;font-size:14px;color:#fff;border:none;cursor:pointer}.btn-confirm:hover{background:#009070}.formula-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.formula-modal{width:1221px;height:702px;background:#fff;border-radius:4px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 12px 48px #0003}.formula-header{height:96px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #F0F0F0;position:relative}.formula-title{color:#4e5969;font-size:18px;font-weight:700;margin:0}.formula-subtitle{color:#4e5969;font-size:14px;margin:4px 0 0}.formula-search-container{width:360px}.search-box{height:48px;border:1.5px solid #D9D9D9;border-radius:4px;display:flex;align-items:center;padding:0 12px;gap:12px}.search-icon{width:20px;height:20px;color:#191919}.search-box input{flex:1;border:none;outline:none;font-size:16px;color:#191919}.search-box input::placeholder{color:#86909c}.formula-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#4e5969}.formula-close:hover{opacity:.7}.formula-content{flex:1;display:flex;padding:24px;gap:24px;overflow:hidden}.formula-left{width:586px;flex-shrink:0;display:flex;flex-direction:column;gap:24px}.formula-display-area label,.keypad-group label{display:block;font-size:16px;color:#4e5969;margin-bottom:8px}.formula-builder-box{width:586px;height:200px;border:2px solid #00AB84;border-radius:4px;padding:16px;display:flex;flex-wrap:wrap;align-content:flex-start;gap:8px;overflow-y:auto;background:#fff;box-sizing:border-box}.formula-text-display{font-size:18px;color:#191919;word-break:break-all;line-height:1.5;font-family:monospace}.formula-placeholder{color:#86909c;font-size:16px}.formula-keypad-section{display:flex;flex-direction:column;gap:24px}.keypad-grid-unified{display:grid;grid-template-columns:repeat(10,1fr);gap:6.77px;width:586px}.key-btn{width:52.5px;height:52.5px;background:#f3f3f3;border:none;border-radius:3.39px;font-size:22px;color:#191919;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.key-btn:hover{background:#e5e5e5}.key-btn:active{background:#d9d9d9;transform:translateY(1px);box-shadow:inset 0 2px 4px #0000001a}.key-btn.backspace-btn{background:#f3f3f3}.key-btn.number-btn{background:#fff;border:1px solid #E5E6EB}.key-btn.number-btn:hover{background:#f2f3f5}.key-btn.operator-btn{background:#f7f8fa;color:#00ab84;font-weight:600}.key-btn.operator-btn:hover{background:#e8fffb}.btn-clear-all{background:none;border:none;color:#f53f3f;font-size:14px;font-weight:500;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s}.btn-clear-all:hover{background:#ffeeec}.btn-clear-all:active{background:#ffdedc}.formula-right{flex:1;border-radius:4px;border:1px solid #F0F0F0;overflow:hidden;display:flex;flex-direction:column}.channel-table-container{flex:1;overflow-y:auto}.channel-table th{background:#f3f3f3;height:36px;padding:0 12px;text-align:left;font-size:13px;font-weight:700;color:#191919;position:sticky;top:0;white-space:nowrap}.channel-table td{height:40px;padding:0 12px;border-bottom:1px solid #F0F0F0;font-size:13px;color:#191919;cursor:pointer;white-space:nowrap}.channel-table tr:hover td{background:#00ab841a}.formula-footer{height:72px;padding:0 24px;display:flex;align-items:center;justify-content:center;gap:32px;border-top:1px solid #F0F0F0;background:#fafafa}.btn-formula-cancel{height:36px;padding:0 32px;background:#e5e5e5;border:none;border-radius:3px;font-size:14px;color:#4e5969;cursor:pointer;font-family:PingFang SC,sans-serif}.btn-formula-confirm{height:36px;padding:0 32px;background:#00ab84;border:none;border-radius:3px;font-size:14px;color:#fff;cursor:pointer;font-family:PingFang SC,sans-serif}.btn-formula-confirm:hover{background:#009070}.edit-channel-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.edit-channel-modal{width:520px;background:#fff;border-radius:8px;position:relative;display:flex;flex-direction:column;box-shadow:0 12px 48px #00000026;overflow:hidden}.edit-channel-header{height:56px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #F0F0F0}.edit-channel-title{font-size:18px;font-weight:700;color:#191919;font-family:Arial,sans-serif}.edit-channel-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:4px;transition:background .2s}.edit-channel-close:hover{background:#0000000d}.edit-channel-body{padding:24px;display:flex;flex-direction:column;gap:16px}.edit-form-item{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:12px}.edit-form-label{flex:1;font-size:14px;color:#000000e6;font-family:PingFang SC,sans-serif;text-transform:capitalize}.edit-form-input-wrapper{width:253px;height:32px;padding:0 8px;border:1px solid #D4D4D8;border-radius:3px;display:flex;align-items:center;background:#fff}.edit-form-input{width:100%;height:100%;border:none;outline:none;font-size:14px;color:#000000e6;font-family:Arial,sans-serif}.edit-channel-footer{height:64px;padding:0 24px;display:flex;align-items:center;justify-content:center;gap:24px;border-top:1px solid #F0F0F0;background:#fafafa}.btn-edit-cancel{padding:6px 32px;background:#e5e5e5;border-radius:3px;font-size:14px;color:#000000e6;border:none;cursor:pointer;font-family:PingFang SC,sans-serif}.btn-edit-confirm{padding:6px 32px;background:#00ab84;border-radius:3px;font-size:14px;color:#fff;border:none;cursor:pointer;font-family:PingFang SC,sans-serif}.btn-edit-confirm:hover{background:#009070}.layout-setting-page{display:flex!important;flex-direction:column!important;align-items:stretch!important;justify-content:flex-start!important;width:100%!important;height:100%!important;overflow:hidden}.layout-header{height:auto;min-height:68px;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #F0F0F0;flex-shrink:0}.layout-header h2{margin:0;font-size:18px;font-weight:700;color:#191919;font-family:Arial,sans-serif}.layout-header p{margin:4px 0 0;font-size:14px;color:#86909c}.layout-content{flex:1;padding:20px 24px;display:flex;flex-direction:row;gap:20px;overflow-x:auto;overflow-y:hidden;align-items:stretch}.layout-card{background:#fff;border:1px solid #E7E7E7;border-radius:8px;display:flex;flex-direction:column;overflow:hidden}.layout-card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #F0F0F0;flex-shrink:0}.layout-card-header .card-title{font-size:15px;font-weight:600;color:#191919;font-family:PingFang SC,sans-serif}.layout-card-header .card-count{font-size:12px;color:#86909c;margin-left:6px;font-weight:400}.layout-card-body{flex:1;overflow-y:auto}.layout-card.location-card,.layout-card.meapoint-card{flex:1;min-width:320px}.layout-card.channel-card{flex:1.5;min-width:450px}.layout-list-item{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid #F0F0F0;cursor:pointer;transition:background .15s;-webkit-user-select:none;user-select:none}.layout-list-item:last-child{border-bottom:none}.layout-list-item:hover{background:#00ab840a}.layout-list-item.active{background:#00ab8414;border-left:3px solid #00AB84}.layout-list-item .item-name{font-size:14px;color:#191919;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layout-list-item.active .item-name{color:#00ab84;font-weight:600}.layout-list-item .item-actions{display:flex;gap:4px;flex-shrink:0}.layout-list-item .item-badge{font-size:11px;color:#86909c;background:#f2f3f5;padding:2px 8px;border-radius:10px;margin-right:8px;flex-shrink:0}.layout-add-row{display:flex;align-items:center;gap:8px;padding:8px 16px;border-top:1px solid #F0F0F0;flex-shrink:0}.layout-add-row input{flex:1;height:32px;background:#f8f9fa;border:1px solid #D9D9D9;border-radius:4px;padding:0 10px;font-size:13px;color:#191919;outline:none;box-sizing:border-box}.layout-add-row input:focus{border-color:#00ab84;background:#fff}.layout-add-row input::placeholder{color:silver}.btn-layout-action{height:32px;padding:0 12px;background:#00ab84;border:none;border-radius:4px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap;flex-shrink:0}.btn-layout-action:hover{background:#009070}.btn-layout-action:disabled{background:silver;cursor:not-allowed}.btn-layout-icon{width:26px;height:26px;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .15s;padding:0}.btn-layout-icon:hover{background:#0000000f}.layout-channel-table{width:100%;border-collapse:collapse}.layout-channel-table th{background:#f3f3f3;text-align:left;padding:10px 16px;font-size:13px;font-weight:600;color:#191919;border-bottom:1px solid #E7E7E7;position:sticky;top:0;z-index:1}.layout-channel-table td{padding:10px 16px;font-size:13px;color:#191919;border-bottom:1px solid #F0F0F0}.layout-channel-table tr:last-child td{border-bottom:none}.layout-channel-table tr:hover td{background:#00000005}.layout-empty{display:flex;align-items:center;justify-content:center;padding:32px 16px;color:silver;font-size:13px;text-align:center}.layout-context-bar{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#fafbfc;border-bottom:1px solid #F0F0F0;font-size:13px;color:#86909c;flex-shrink:0}.layout-context-bar .ctx-label{color:#00ab84;font-weight:600}.layout-context-bar .ctx-separator{color:#d0d0d0}.layout-inline-input{width:100%;height:30px;background:#f8f9fa;border:1px solid #00AB84;border-radius:4px;padding:0 8px;font-size:13px;color:#191919;outline:none;box-sizing:border-box}.layout-inline-input:focus{background:#fff}.modbus-rtu-page{display:flex!important;flex-direction:column!important;align-items:stretch!important;justify-content:flex-start!important;width:100%!important;height:100%!important}.modbus-select-wrapper{width:280px;height:32px}.modbus-select{width:100%;height:100%;padding:0 8px;background:#fff;border-radius:3px;border:1px solid #DCDCDC;font-size:14px;color:#000000e6;outline:none;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.modbus-range-hint{position:absolute;left:288px;top:5px;font-size:14px;color:#000000e6;font-family:PingFang SC,sans-serif;white-space:nowrap}.modbus-tcp-page{display:flex!important;flex-direction:column!important;align-items:stretch!important;justify-content:flex-start!important;width:100%!important;height:100%!important}.modbus-header{height:68px;padding:0 24px;display:flex;align-items:center;border-bottom:1px solid #F0F0F0;flex-shrink:0}.modbus-title{font-size:18px;font-weight:700;color:#191919;font-family:Arial,sans-serif}.modbus-body{flex:1;padding:40px 24px;display:flex;flex-direction:column;gap:32px}.modbus-row{display:flex;flex-wrap:wrap;gap:32px}.modbus-field{width:308px;display:flex;flex-direction:column;gap:8px}.modbus-label{font-size:14px;color:#000000e6;font-family:PingFang SC,sans-serif}.modbus-input-readonly{width:280px;height:32px;background:#f3f3f3;border-radius:3px;outline:1px solid #DCDCDC;display:flex;align-items:center;padding:0 8px;font-size:14px;color:#000000e6}.modbus-input-container{width:280px;height:32px;position:relative}.modbus-input{width:100%;height:100%;padding:0 8px;background:#fff;border-radius:3px;border:1px solid #DCDCDC;font-size:14px;color:#000000e6;outline:none}.modbus-switch{width:48px;height:24px;background:#e7e7e7;border-radius:12px;position:relative;cursor:pointer;transition:background .3s;display:inline-block;margin-top:4px}.modbus-switch.on{background:#00ab84}.modbus-switch .switch-knob{width:20px;height:20px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:left .3s;box-shadow:0 1px 3px #0003}.modbus-switch.on .switch-knob{left:26px}.modbus-footer{height:72px;padding:0 24px;display:flex;align-items:center;justify-content:flex-end;gap:24px;border-top:1px solid #E7E7E7;flex-shrink:0;margin-top:auto}.btn-modbus-cancel{padding:8px 24px;background:#e7e7e7;border:none;border-radius:3px;font-size:14px;color:#000000e6;cursor:pointer;font-family:PingFang SC,sans-serif;font-weight:600}.btn-modbus-save{min-width:78px;padding:8px 24px;background:#00ab84;border:none;border-radius:3px;font-size:14px;color:#fff;cursor:pointer;font-family:PingFang SC,sans-serif;font-weight:600}.btn-modbus-save:hover{background:#009070}.holding-register-page{display:flex!important;flex-direction:column!important;align-items:stretch!important;justify-content:flex-start!important;width:100%!important;height:100%!important;overflow:hidden}.holding-header{height:auto;min-height:80px;padding:14px 24px;display:flex;align-items:flex-start;justify-content:space-between;border-bottom:1px solid #F0F0F0;flex-shrink:0}.holding-title-section{display:flex;flex-direction:column;gap:4px}.holding-title{font-size:18px;font-weight:700;color:#191919;font-family:Arial,sans-serif;margin:0;line-height:1.5}.holding-subtitle{font-size:14px;color:#ff7200;font-family:Arial,sans-serif;margin:0;line-height:22px}.btn-export-pdf{display:flex;align-items:center;gap:8px;background:#00ab84;color:#fff;border:none;border-radius:3.2px;padding:6px 16px;font-family:Arial,sans-serif;font-size:14px;cursor:pointer;transition:background .2s;margin-top:4px}.btn-export-pdf:hover{background:#009070}.holding-content{flex:1;padding:24px;display:flex;flex-direction:column;gap:24px;overflow-y:hidden}.holding-summary-box{width:100%;padding:20px 32px;border-radius:8px;border:1px solid #E7E7E7;background:#fff;display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-shrink:0}.summary-column{display:flex;flex-direction:column;gap:24px;flex:1}.summary-item{display:flex;gap:4px;flex-direction:row;justify-content:space-between;align-items:center;max-width:320px}.summary-item label{color:#0006;font-size:14px;font-family:PingFang SC,sans-serif;white-space:nowrap}.summary-item span{color:#000000e6;font-size:14px;font-family:PingFang SC,sans-serif;font-weight:400;text-align:right}.holding-table-container{flex:1;border:1px solid #E7E7E7;border-radius:4px;overflow-y:auto}.holding-table{width:100%;border-collapse:collapse}.holding-table th{background:#f3f3f3;text-align:left;padding:12px 16px;font-size:14px;font-weight:600;color:#191919;border-bottom:1px solid #E7E7E7;position:sticky;top:0;z-index:1}.holding-table td{padding:12px 16px;font-size:14px;color:#000000e6;border-bottom:1px solid #E7E7E7}.holding-table tr:hover{background:#00000005}.addr-font{font-family:Courier New,Courier,monospace;font-weight:600;color:#00ab84}.holding-info-text{margin-top:24px}.info-label{display:inline-block;width:150px;text-align:right;vertical-align:top;color:#666;font-size:14px}.info-value{display:inline-block;vertical-align:top;margin-left:8px;font-weight:600;color:#333}.support-page{display:flex!important;flex-direction:column!important;align-items:stretch!important;justify-content:flex-start!important;width:100%!important;height:100%!important}.support-header{height:68px;padding:0 24px;display:flex;align-items:center;border-bottom:1px solid #F0F0F0;flex-shrink:0}.support-title{font-size:18px;font-weight:700;color:#191919;font-family:Arial,sans-serif}.support-body{flex:1;padding:40px 24px;display:flex;flex-direction:column;gap:32px}.support-row{display:flex;flex-wrap:wrap;gap:32px}.support-field{width:308px;display:flex;flex-direction:column;gap:8px}.support-label{font-size:14px;color:#000000e6;font-family:PingFang SC,sans-serif}.required{color:#ff4d4f;margin-left:2px}.support-input-container{width:280px;height:32px;position:relative}.support-input{width:100%;height:100%;padding:0 8px;background:#fff;border-radius:3px;border:1px solid #DCDCDC;font-size:14px;color:#000000e6;outline:none}.support-footer{height:72px;padding:0 24px;display:flex;align-items:center;justify-content:flex-end;gap:24px;border-top:1px solid #E7E7E7;flex-shrink:0;margin-top:auto}.btn-support-cancel{padding:8px 24px;background:#e7e7e7;border:none;border-radius:3px;font-size:14px;color:#000000e6;cursor:pointer;font-family:PingFang SC,sans-serif;font-weight:600}.btn-support-save{min-width:78px;padding:8px 24px;background:#00ab84;border:none;border-radius:3px;font-size:14px;color:#fff;cursor:pointer;font-family:PingFang SC,sans-serif;font-weight:600}.btn-support-save:hover{background:#009070}.verification-page{display:flex!important;flex-direction:column!important;align-items:stretch!important;justify-content:flex-start!important;width:100%!important;height:100%!important}.verification-header{height:68px;padding:0 24px;display:flex;align-items:center;border-bottom:1px solid #F0F0F0;flex-shrink:0;justify-content:space-between}.verification-title{font-size:18px;font-weight:700;color:#191919;font-family:Arial,sans-serif;text-transform:capitalize}.verification-header-icon{width:38px;height:38px;border-radius:38px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.verification-header-icon:hover{background:#0000000d}.verification-body{flex:1;padding:40px 24px;display:flex;flex-direction:column;gap:32px}.verification-row{display:flex;gap:32px;align-items:flex-start}.verification-label-container{width:150px;flex-shrink:0;display:flex;align-items:center;height:32px}.verification-label{font-size:15px;font-weight:600;color:#4e5969;font-family:PingFang SC,sans-serif;line-height:22px}.verification-content{flex:1;display:flex;flex-direction:column}.upload-zone{width:440px;height:201px;background:#fff;border-radius:4px;border:1px dashed #DDDFE6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;cursor:pointer;transition:all .25s ease;position:relative;overflow:hidden;box-sizing:border-box}.upload-zone:hover,.upload-zone.dragging{border-color:#00ab84;background:#f0fbf9}.upload-icon{width:48px;height:48px;color:#86909c;transition:color .25s}.upload-zone:hover .upload-icon,.upload-zone.dragging .upload-icon{color:#00ab84}.upload-text{font-size:14px;font-weight:700;color:#191919;font-family:Arial,sans-serif;text-transform:uppercase;text-align:center}.file-input-hidden{display:none}.file-cards-list{margin-top:16px;display:flex;flex-direction:column;gap:8px;width:440px}.file-card{display:flex;align-items:center;padding:8px 12px;background:#f8f9fa;border:1px solid #E5E6EB;border-radius:4px;gap:8px;font-size:13px;color:#1d2129}.file-card .file-icon{font-size:16px}.file-card .file-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px;font-weight:500}.file-card .file-size{color:#86909c;font-size:11px}.file-card .btn-remove{cursor:pointer;color:#86909c;margin-left:auto;border:none;background:none;font-size:16px;display:flex;align-items:center;justify-content:center;padding:4px;border-radius:50%}.file-card .btn-remove:hover{color:#f53f3f;background:#f53f3f0d}.result-box{width:440px;min-height:48px;background:#f3f3f3;border-radius:4px;border:1px solid #D9D9D9;display:flex;align-items:center;padding:10px 16px;font-size:14px;font-family:Arial,sans-serif;color:#4e5969;transition:all .25s ease;line-height:1.4;box-sizing:border-box}.result-box.success{background:#f0fbf9;border-color:#b2e5d9;color:#00ab84;font-weight:700}.result-box.error{background:#ffece8;border-color:#ffb4ab;color:#f53f3f}.result-box.verifying{background:#f2f3f5;border-color:#e5e6eb;color:#86909c}.result-details{margin-top:12px;font-size:12px;font-family:monospace;color:#4e5969;background:#f8f9fa;padding:12px;border-radius:4px;border:1px solid #E5E6EB;width:440px;word-break:break-all;white-space:pre-wrap}.result-details-title{font-weight:700;margin-bottom:6px;color:#1d2129}.app-container{display:flex;width:100vw;height:100vh;overflow:hidden;background-color:var(--bg-color)}.sidebar-header{height:var(--topbar-height);background:var(--primary-color);padding:0 12px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border-color);box-sizing:border-box;overflow:hidden}.main-logo{height:16px;object-fit:contain}.logo-text{font-weight:700;font-size:18px;color:#181818;font-family:Arial,sans-serif;line-height:22px}.nav-list{flex:1;padding:16px 8px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.nav-item{display:flex;align-items:center;height:40px;padding:7px 12px;gap:8px;color:#333;text-decoration:none;font-size:14px;font-family:PingFang SC,sans-serif;line-height:22px;transition:all var(--transition-speed);border-radius:3px;margin:0 4px;position:relative;z-index:1;width:100%;box-sizing:border-box}.nav-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-icon img{display:block;width:100%;height:100%;object-fit:contain}.nav-item:hover{background:#0000000a}.nav-item.active{background:#00ab84;color:#fff;width:100%;margin:0;padding-left:16px;padding-right:16px;border-top-right-radius:24px;border-bottom-right-radius:24px}.nav-item.active span{color:#fff}.nav-item.active .nav-icon img{filter:brightness(0) invert(1)}.nav-group{margin-bottom:2px}.submenu{overflow:hidden;max-height:0;display:flex;flex-direction:column;transition:max-height .3s ease}.submenu.submenu-open{max-height:400px}.submenu-item{display:flex;align-items:center;gap:10px;padding:8px 16px 8px 48px;font-size:13px;color:#0000008c;text-decoration:none;font-family:PingFang SC,sans-serif;transition:all var(--transition-speed);position:relative}.submenu-item:hover{color:var(--accent-color)}.submenu-item.active{background:#00ab84;color:#fff;width:100%;margin:0;padding-left:48px;border-top-right-radius:24px;border-bottom-right-radius:24px}.submenu-item.active span{color:#fff}.chevron{margin-left:auto;display:flex;align-items:center}.submenu-item.submenu-item-active{color:var(--accent-color);font-weight:600}.submenu-dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0;opacity:.5}.submenu-item.submenu-item-active .submenu-dot{opacity:1;background:var(--accent-color)}.sidebar-footer-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .2s}.sidebar-footer-icon:hover{opacity:.8}.topbar-icon-btn{width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.topbar-icon-btn:hover{background:#00000014}.sidebar-footer{padding:16px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-start;box-sizing:border-box;overflow:hidden}.sidebar{width:var(--sidebar-width);height:100%;background:var(--sidebar-bg);display:flex;flex-direction:column;flex-shrink:0;z-index:20;overflow:hidden;box-sizing:border-box}.main-wrapper{flex:1;display:flex;flex-direction:column;min-width:0}.top-bar{height:var(--topbar-height);background:var(--primary-color);display:flex;justify-content:space-between;align-items:center;padding:0 24px;gap:16px;flex-shrink:0}.breadcrumb-nav{display:flex;align-items:center;gap:8px;font-family:PingFang SC,sans-serif;font-size:14px;text-decoration:none}.breadcrumb-item{color:#0006;font-size:14px;font-family:PingFang SC,sans-serif;font-weight:600;line-height:22px;text-decoration:none}.breadcrumb-item.active{color:#000000e6;word-wrap:break-word}.breadcrumb-separator{color:#0003}.top-bar-right{display:flex;align-items:center;gap:16px}.user-profile{display:flex;align-items:center;gap:8px;padding:5px 6px;cursor:pointer;border-radius:4px;transition:background .2s}.user-profile:hover{background:#0000000d}.user-avatar{width:24px;height:24px;object-fit:cover;opacity:.9}.user-info{display:flex;flex-direction:column;text-align:left}.user-name{font-size:14px;font-weight:500;color:var(--text-primary);font-family:PingFang SC,sans-serif}.content-area{flex:1;padding:24px;overflow-y:auto}.content-card{width:100%;height:100%;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #0000000f}.empty-state{display:flex;flex-direction:column;align-items:center;gap:48px}.empty-icon{width:20px;height:20px;color:#8c8c8c}.empty-text{color:#4e5969;font-size:16px;font-family:PingFang SC,sans-serif;font-weight:700}.graphic-view{flex-direction:column!important;padding:24px;justify-content:flex-start!important;gap:20px}.graphic-header{width:100%;display:flex;justify-content:space-between;align-items:center}.graphic-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--text-primary)}.add-graphic-btn{display:flex;align-items:center;gap:6px;background:var(--primary-color);padding:6px 12px;border-radius:4px;font-size:14px;font-weight:500}.graphic-content{flex:1;width:100%;display:flex;gap:16px}.y-axis{display:flex;flex-direction:column;justify-content:space-between;padding:0 8px;color:#0006;font-size:12px;height:calc(100% - 30px)}.chart-main{flex:1;display:flex;flex-direction:column}.channel-grid{flex:1;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);gap:16px;border-left:1px solid var(--border-color);border-bottom:1px solid var(--border-color);padding:16px}.add-channel-item{background:#f8f9fa;border:1px dashed var(--border-color);border-radius:6px;display:flex;align-items:center;justify-content:center;gap:8px;color:#0006;font-size:14px;transition:all .2s}.add-channel-item:hover{background:#00ab840d;border-color:var(--accent-color);color:var(--accent-color)}.x-axis{height:30px;display:flex;justify-content:space-between;align-items:center;padding:0 16px;color:#0006;font-size:12px}.graphic-info-bar{width:100%;padding:10px 16px;background:#fdf6ec;border-radius:4px;display:flex;align-items:center;gap:8px;color:#e6a23c;font-size:14px}.graphic-view{display:flex!important;flex-direction:column!important;padding:0!important;align-items:stretch!important;justify-content:flex-start!important;overflow:hidden}.card-header{height:68px;padding:0 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #F0F0F0}.channel-bar{height:72px;background:#fff;display:flex;align-items:center;padding:0 24px;gap:4px;overflow:hidden;border-bottom:1px solid #F0F0F0}.scroll-wrapper{-ms-overflow-style:none;scrollbar-width:none}.scroll-wrapper::-webkit-scrollbar{display:none}.channel-item{width:166px;min-width:166px;height:72px;background:#f3f3f3;display:flex;align-items:center;padding:0 17px;gap:2px;cursor:pointer;flex-shrink:0;box-sizing:border-box;overflow:hidden}.channel-item span{font-family:Arial,sans-serif;font-weight:700;font-size:18px;color:#191919;white-space:nowrap}.chart-section{flex:1;display:flex;padding:40px 24px;gap:0;position:relative}.y-axis-labels{display:flex;flex-direction:column;justify-content:space-between;height:calc(100% - 40px);width:46px;color:#86909c;font-family:Arial;font-weight:700;font-size:14px;padding-bottom:0}.info-footer{margin:16px 24px;padding:12px 16px;background:#fff7e8;border:1px solid #FFE4BA;border-radius:4px;display:flex;align-items:center;gap:8px;color:#4e5969;font-size:14px}.modal-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-container{width:1136px;max-width:90vw;background:#fff;border-radius:8px;box-shadow:0 10px 30px #0003;display:flex;flex-direction:column;overflow:hidden}.modal-header{height:68px;padding:0 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #E7E7E7}.modal-header h3{font-size:18px;font-weight:700;color:#191919}.modal-search-bar{padding:18px 24px;display:flex;align-items:center}.search-input-wrapper{position:relative;width:320px}.search-input-wrapper input{width:100%;height:32px;padding:0 12px 0 32px;border:1px solid #DCDCDC;border-radius:3px;font-size:14px}.search-input-wrapper .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#0006}.modal-content-table{padding:0 24px;flex:1;overflow-y:auto;max-height:500px}.channel-table{width:100%;border-collapse:collapse}.channel-table th{background:#f3f3f3;text-align:left;padding:16px 24px;font-weight:600;font-size:14px;color:#191919;border-bottom:1px solid #E7E7E7;position:sticky;top:0;z-index:2}.channel-table td{padding:16px 24px;font-size:14px;color:#000000e6;border-bottom:1px solid #E7E7E7}.channel-table tr:hover{background:#00000005}.modal-footer{height:72px;padding:0 24px;display:flex;justify-content:center;align-items:center;gap:24px;border-top:1px solid #E7E7E7}.btn-secondary{padding:6px 32px;border:1px solid #DCDCDC;border-radius:4px;font-size:14px;font-weight:500;color:#4e5969}.btn-primary{padding:6px 32px;background:var(--primary-color);border-radius:4px;font-size:14px;font-weight:500;color:#191919}.logger-settings-page{display:flex!important;flex-direction:column!important;padding:0!important;align-items:stretch!important;justify-content:flex-start!important;overflow:hidden}.create-logger-btn{display:flex;align-items:center;gap:6px;height:32px;padding:0 16px;background:#00ab84;border:none;border-radius:3.2px;color:#fff;font-family:Arial,sans-serif;font-size:14px;font-weight:400;cursor:pointer;transition:background .2s;text-transform:capitalize}.create-logger-btn:hover{background:#009070}.logger-body{flex:1;display:flex;align-items:center;justify-content:center;overflow-y:auto}.logger-empty-state{display:flex;flex-direction:column;align-items:center;gap:16px}.logger-table{width:100%;border-collapse:collapse}.logger-table th{background:#f3f3f3;text-align:left;padding:14px 24px;font-size:14px;font-weight:600;color:#191919;border-bottom:1px solid #E7E7E7}.logger-table td{padding:14px 24px;font-size:14px;color:#000000e6;border-bottom:1px solid #E7E7E7}.logger-table tr:hover td{background:#00000005}.btn-icon{padding:4px 12px;border:1px solid #DCDCDC;border-radius:3px;font-size:13px;color:#4e5969;cursor:pointer;margin-right:6px}.btn-danger{color:#f53f3f;border-color:#f53f3f}.drawer-form-row{display:flex;align-items:center;min-height:48px;padding:8px 0;border-bottom:none}.drawer-label{width:149px;min-width:149px;font-size:14px;font-family:PingFang SC,sans-serif;font-weight:400;color:#000000e6;line-height:22px;display:flex;align-items:center;gap:2px}.required{color:#d54941;font-size:14px;line-height:22px}.drawer-input{flex:1;height:32px;padding:5px 8px;background:#fff;border:1px solid #DCDCDC;border-radius:3px;font-size:14px;font-family:PingFang SC,sans-serif;font-weight:400;color:#000000e6;line-height:22px;outline:none;transition:border-color .2s;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.drawer-input::placeholder{color:#0006}.drawer-input:focus{border-color:#00ab84}.nav-item.disabled,.submenu-item.disabled{opacity:.4;cursor:not-allowed;pointer-events:none;background:none!important;color:#0006!important}.nav-item.disabled:hover,.submenu-item.disabled:hover{background:none!important;color:#0006!important}
