html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}@-ms-viewport{width:device-width}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{padding:.2em;background-color:#feffe6}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif}#app{width:100%;height:100%}:root{--primary-color: #1890ff;--success-color: #52c41a;--warning-color: #faad14;--error-color: #f5222d;--text-color: rgba(0, 0, 0, .85);--text-color-secondary: rgba(0, 0, 0, .65);--border-color: #d9d9d9;--bg-color: #ffffff;--bg-color-secondary: #fafafa}[data-theme=dark]{--primary-color: #1890ff;--success-color: #52c41a;--warning-color: #faad14;--error-color: #f5222d;--text-color: rgba(255, 255, 255, .85);--text-color-secondary: rgba(255, 255, 255, .65);--border-color: #434343;--bg-color: #141414;--bg-color-secondary: #1f1f1f}:root{--surface-radius: 8px;--mobile-page-gutter: 8px}.main-layout,.simple-layout{min-width:0}.main-layout .header,.simple-layout .header{position:sticky;top:0;z-index:100;flex-shrink:0}.main-layout .header-left,.simple-layout .header-left{min-width:0;flex:1}.main-layout .logo,.simple-layout .logo{flex-shrink:0}.desktop-top-menu{flex:1;min-width:0;border-bottom:0;background:transparent}.main-layout .header-right,.simple-layout .header-right{flex-shrink:0;min-width:0}.main-layout .layout-body{min-height:0;flex:1;overflow:hidden}.main-layout .content,.simple-layout .content{min-width:0;overflow-x:hidden}.mobile-menu-button{display:none}.user-menu-button{max-width:180px;display:inline-flex;align-items:center;gap:6px}.user-menu-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-nav-title{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;font-weight:700}.mobile-nav-drawer .ant-drawer-header{padding:12px 16px}.mobile-nav-drawer .ant-drawer-title{min-width:0}.mobile-nav-drawer .ant-menu{border-inline-end:0}.mobile-nav-drawer .ant-menu-item,.mobile-nav-drawer .ant-menu-submenu-title{margin-inline:8px;width:calc(100% - 16px);border-radius:8px}@media (max-width: 768px){html,body,#app{min-width:0;overflow:hidden;overscroll-behavior:none;text-size-adjust:100%;-webkit-text-size-adjust:100%}img,svg,canvas,video{max-width:100%}button,input,textarea,select{font:inherit}.main-layout,.simple-layout{height:100dvh;min-height:100dvh;overflow:hidden}.main-layout .header,.simple-layout .header{height:56px;line-height:56px;padding:0 max(12px,env(safe-area-inset-right)) 0 max(12px,env(safe-area-inset-left));gap:8px}.main-layout .header-left,.simple-layout .header-left{gap:8px;flex:1 1 auto}.main-layout .logo,.simple-layout .logo{font-size:18px!important;line-height:1}.desktop-top-menu{display:none}.main-layout .header-right,.simple-layout .header-right{max-width:calc(100vw - 124px)}.main-layout .header-right .ant-space,.simple-layout .header-right .ant-space{gap:2px!important;flex-wrap:nowrap}.main-layout .header-right .ant-btn,.simple-layout .header-right .ant-btn{padding-inline:6px}.mobile-menu-button{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.main-layout .ant-layout-sider{display:none}.main-layout .content,.simple-layout .content{padding:var(--mobile-page-gutter);-webkit-overflow-scrolling:touch}.user-menu-button{max-width:40px;padding-inline:6px}.user-menu-name{display:none}.ant-layout,.ant-layout-content{min-width:0}.ant-card,.ant-modal-content,.ant-drawer-content,.ant-popover-inner{border-radius:var(--surface-radius)}.ant-card-head{min-height:42px;padding-inline:12px}.ant-card-head-wrapper{display:flex;flex-direction:column;align-items:stretch;gap:8px;width:100%}.ant-card-head-title{min-width:0;padding:10px 0 0;white-space:normal;font-size:17px;line-height:1.35}.ant-card-extra{margin-inline-start:0;padding:0 0 8px;width:100%}.ant-card-extra .ant-space{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px!important;width:100%;align-items:stretch}.ant-card-extra .ant-space-item,.ant-card-extra .ant-space-item>*,.ant-card-extra .ant-upload-wrapper,.ant-card-extra .ant-upload,.ant-card-extra .ant-upload-select,.ant-card-extra .ant-dropdown-trigger{display:flex!important;width:100%!important;min-width:0}.ant-card-extra .ant-btn{width:100%!important;min-width:0;height:34px;padding-inline:10px;display:inline-flex!important;align-items:center;justify-content:center;gap:6px;font-size:13px;line-height:1}.ant-card-extra .ant-btn>.anticon+span,.ant-card-extra .ant-btn>span:not(.anticon){min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-flex;align-items:center}.ant-card-body{padding:12px!important}.search-form-container{padding:10px;margin-bottom:12px;border-radius:8px}.ant-row:not(.ant-form-item-row){row-gap:12px}.ant-row:not(.ant-form-item-row)>[class*=ant-col]{flex:0 0 100%!important;max-width:100%!important}.ant-form-inline{display:flex;flex-direction:column;align-items:stretch;width:100%}.ant-form-inline .ant-form-item{width:100%;margin-right:0;margin-bottom:10px}.ant-form-item{margin-bottom:14px}.ant-form-item-label{padding-bottom:4px;text-align:left}.ant-form-item-label>label{height:auto;white-space:normal}.ant-form-item-control,.ant-form-item-control-input,.ant-form-item-control-input-content,.ant-form .ant-col{flex:1 1 100%;max-width:100%;min-width:0}.ant-form .ant-col-offset-6{margin-left:0!important}.ant-input,.ant-input-affix-wrapper,.ant-input-number,.ant-picker,.ant-select,.ant-cascader-picker,.ant-mentions,.ant-upload,.ant-upload-select{width:100%!important;max-width:100%}.ant-form-inline .ant-btn+.ant-btn,.ant-form-inline .ant-checkbox-wrapper{margin-left:0!important}.ant-space{max-width:100%;flex-wrap:wrap;row-gap:8px}.ant-btn{max-width:100%;display:inline-flex!important;align-items:center;gap:6px}.ant-btn>.anticon+span,.ant-btn>span:not(.anticon){min-width:0;overflow:hidden;text-overflow:ellipsis;display:inline-flex;align-items:center}.ant-table-wrapper{width:100%;max-width:100%;overflow-x:auto;border-radius:var(--surface-radius);-webkit-overflow-scrolling:touch}.ant-table{min-width:max-content;font-size:12px}.ant-table-container,.ant-table-content,.ant-table-body{min-width:100%}.ant-table-thead>tr>th,.ant-table-tbody>tr>td{padding:8px 10px;white-space:nowrap}.ant-table-cell-fix-left,.ant-table-cell-fix-right{position:static!important;box-shadow:none!important}.ant-table-pagination{margin:10px 0 0!important}.ant-pagination{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:4px 0}.ant-pagination-options{margin-left:0}.ant-modal-root .ant-modal-wrap{overflow:hidden auto}.ant-modal{max-width:calc(100vw - 16px);margin:8px auto;top:0;padding-bottom:8px}.ant-modal-content{display:flex;flex-direction:column;max-height:calc(100dvh - 16px);overflow:hidden}.ant-modal-header{padding:12px 16px}.ant-modal-title{line-height:1.35}.ant-modal-body{flex:1;min-height:0;overflow:auto;padding:12px!important;-webkit-overflow-scrolling:touch}.ant-modal-footer{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px;padding:8px 12px}.ant-modal-footer .ant-btn{margin-inline-start:0!important}.ant-drawer-content-wrapper{max-width:100vw}.ant-drawer-body{padding:12px;overflow:auto;-webkit-overflow-scrolling:touch}.ant-popover{max-width:calc(100vw - 16px)}.ant-popover-inner-content{max-height:calc(100dvh - 96px);overflow:auto}.ant-tabs-nav{margin-bottom:8px!important}.ant-tabs-nav-wrap{overflow:auto hidden}.ant-descriptions-view{overflow-x:auto;-webkit-overflow-scrolling:touch}.ant-descriptions-item-label,.ant-descriptions-item-content{padding:8px!important}.home-container .dashboard-filters,.dashboard-content .dashboard-filters{padding:12px 8px;margin:0 0 12px;background:var(--bg-color-secondary);border-radius:8px}.home-container .canvas-layout,.dashboard-content .canvas-layout{display:flex;flex-direction:column;gap:12px;height:auto!important;min-height:0;background:transparent}.home-container .canvas-item,.dashboard-content .canvas-item{position:relative!important;inset:auto!important;width:100%!important;min-height:260px;height:auto!important;padding:12px;overflow:hidden}.home-container .canvas-item .item-title,.dashboard-content .canvas-item .item-title{font-size:13px;margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-container .canvas-item .chart-renderer,.dashboard-content .canvas-item .chart-renderer{min-height:220px;overflow:hidden}.chart-renderer .switch-header{margin-bottom:8px;text-align:left}.chart-renderer .switch-controls{flex-direction:column;align-items:stretch;gap:8px}.chart-renderer .switch-controls .ant-radio-group{display:flex;flex-wrap:wrap;gap:4px}.chart-renderer .switch-controls .ant-radio-button-wrapper{font-size:12px;padding:0 10px;height:30px;line-height:28px}.chart-renderer .vehicle-selector{flex-wrap:wrap;gap:6px}.chart-renderer .vehicle-selector .ant-select{min-width:0;flex:1}.chart-renderer .vehicle-selector .ant-btn{flex-shrink:0}.card-container .card-value{font-size:24px}.card-container .card-label{font-size:12px}.home-container .dashboard-filters,.dashboard-content .dashboard-filters{overflow-x:auto;-webkit-overflow-scrolling:touch}.home-container .dashboard-filters .ant-space,.dashboard-content .dashboard-filters .ant-space{display:flex;flex-wrap:nowrap;width:max-content;min-width:100%}.home-container .dashboard-filters .ant-select,.dashboard-content .dashboard-filters .ant-select{min-width:140px;max-width:200px}.editor-container{flex-direction:column;height:auto!important;min-height:0}.component-picker,.config-panel{width:100%!important;max-height:340px;overflow:auto}.editor-container .canvas-container{min-height:560px;overflow:auto}.editor-container .canvas-card{height:560px}.editor-container .canvas-layout{width:760px;min-width:760px;height:720px}.calendar-container{overflow-x:auto;border-radius:8px;-webkit-overflow-scrolling:touch}.calendar-header,.calendar-row{min-width:760px}.vehicle-column{width:160px!important;min-width:160px!important}.date-column,.date-cell{min-width:68px!important}.booking-purpose{display:none}.hot-filters-section,.hot-filters-main{flex-direction:column;align-items:stretch;min-width:0}.legend-hot-right{max-width:100%;margin-left:0}.column-settings-menu{max-width:min(360px,100vw - 48px);max-height:60vh;overflow:auto}.column-settings-grid{grid-template-columns:1fr!important}#vrVehicleChart,#vrPrefixChart{height:360px!important}div:has(>#vrVehicleChart){min-height:360px}div:has(>#vrVehicleChart),div:has(>#vrPrefixChart){flex:1 1 100%!important;min-width:100%}div:has(>#vrVehicleChart)+div:has(>#vrPrefixChart){margin-top:12px}.dtc-filter-dropdown,.table-filter-dropdown{max-width:calc(100vw - 32px)}.dtc-filter-dropdown [style*="width: 320px"],.table-filter-dropdown [style*="width: 320px"]{width:min(320px,100vw - 56px)!important}.software-version-toolbar,.upload-record-toolbar,.software-version-toolbar .ant-space-item,.upload-record-toolbar .ant-space-item,.software-version-toolbar .ant-btn,.upload-record-toolbar .ant-btn{width:100%}.vehicle-action-group,.record-action-links,.booking-action-grid,.operation-log-search .action-buttons{justify-content:flex-start;flex-wrap:wrap!important;white-space:normal!important}.operation-log-search{flex-direction:column;align-items:stretch;overflow-x:visible;white-space:normal}.operation-log-search .search-actions{margin-left:0}.personal-settings{padding:0!important}.personal-settings .ant-row{margin-left:0!important;margin-right:0!important}.personal-settings .ant-col{padding-left:0!important;padding-right:0!important}.personal-settings .ant-form-item-control-offset{margin-left:0!important}.rule-row{padding:12px!important;border-radius:6px}.rule-row-main{flex-direction:column;align-items:stretch!important;gap:10px}.rule-segment{flex-wrap:wrap;align-items:stretch!important;gap:6px}.rule-operator-select{width:64px!important;flex:0 0 auto}.rule-value-input{width:auto!important;flex:1 1 180px;min-width:0}.rule-inline-actions{width:100%;margin-left:0!important;flex-wrap:wrap;align-items:stretch!important}.rule-inline-actions .ant-btn{flex:1 1 140px}.preview-textarea textarea{white-space:pre-wrap!important;word-break:break-word}.heartbeat-chart{height:280px!important}.heartbeat-toolbar,.dashboard-filter-form,.heartbeat-toolbar .ant-space-item,.dashboard-filter-form .ant-form-item,.dashboard-filter-form .ant-form-item-control,.dashboard-filter-form .ant-form-item-control-input,.dashboard-filter-form .ant-form-item-control-input-content{width:100%}.heartbeat-toolbar .ant-select,.heartbeat-toolbar .ant-picker,.heartbeat-toolbar .ant-btn,.dashboard-filter-input,.dashboard-filter-range,.dashboard-filter-form .ant-btn{width:100%!important}.dashboard-filter-action{margin-left:0!important}.dashboard-link-value{display:block;max-width:calc(100vw - 72px)}.qrcode-zoom-modal .ant-modal{width:calc(100vw - 16px)!important;max-width:calc(100vw - 16px);top:8px}.qrcode-zoom-modal .ant-modal-content{height:calc(100vh - 16px)}.qrcode-zoom-modal .ant-modal-body>div{padding:8px!important}.qrcode-zoom-modal img{width:min(86vw,70vh)!important;height:min(86vw,70vh)!important}.draggable-modal{position:fixed!important;left:8px!important;right:8px;bottom:8px;top:auto!important;width:auto!important;height:min(42vh,320px)!important;max-height:calc(100vh - 96px);resize:none!important}.records-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.timeline-ruler,.datazoom-slider,.records-track{min-width:720px}.record-detail-popover{min-width:0!important;max-width:calc(100vw - 48px)}.component-editor .ant-tabs-content-holder,.ant-tabs-content-holder{min-width:0}.cm-editor{max-width:100%;min-height:260px;font-size:12px}}@media (max-width: 480px){.ant-card-body{padding:10px!important}.ant-modal{max-width:calc(100vw - 8px);margin:4px auto}.ant-modal-content{max-height:calc(100dvh - 8px)}}
