*{box-sizing:border-box;margin:0;padding:0}html{scrollbar-width:thin;overflow-y:scroll}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.login-container{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);flex-direction:column;min-height:100vh;display:flex}.login-header{color:#fff;justify-content:space-between;align-items:center;padding:16px 32px;display:flex}.login-logo{align-items:center;gap:12px;font-size:20px;font-weight:700;display:flex}.login-header-right{align-items:center;gap:24px;display:flex}.login-header-right .ant-space-item{color:#fff}.language-select .ant-select-selection-item,.language-select .ant-select-selection-placeholder,.language-select .ant-select-arrow{color:#fff!important}.language-select .ant-select-arrow svg{fill:#fff!important;color:#fff!important}.login-header-right a{color:#fff}.login-main{flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.login-box{background:#fff;border-radius:12px;width:100%;max-width:420px;padding:40px;box-shadow:0 20px 60px #0000004d}.login-title{text-align:center;margin-bottom:32px}.login-title h1{color:#1890ff;margin-bottom:8px;font-size:28px}.login-title p{color:#666;font-size:14px}.login-tabs{margin-top:16px}.login-tabs .ant-tabs-nav{width:100%;margin-bottom:24px}.login-tabs .ant-tabs-nav-list{justify-content:center;width:100%}.login-tabs .ant-tabs-tab{color:#666;font-size:16px;font-weight:500}.login-tabs .ant-tabs-tab-active{color:#1890ff}.login-tabs .ant-tabs-ink-bar{background:#1890ff}.wechat-login{flex-direction:column;align-items:center;padding:24px 0;display:flex}.wechat-qrcode{background:#fff;border:1px solid #e8e8e8;border-radius:8px;justify-content:center;align-items:center;width:180px;height:180px;margin-bottom:16px;display:flex}.qrcode-placeholder{flex-direction:column;align-items:center;gap:12px;display:flex}.qrcode-icon{background:#07c160;border-radius:12px;justify-content:center;align-items:center;width:120px;height:120px;display:flex}.qrcode-placeholder p{color:#666;margin:0;font-size:14px}.wechat-tip{color:#999;margin:0;font-size:12px}.login-footer{text-align:center;color:#fffc;padding:16px;font-size:12px}.main-layout{min-height:100vh}.main-header{z-index:100;background:#fff;justify-content:space-between;align-items:center;height:50px;margin-top:0;margin-bottom:16px;padding:0 20px 6px;display:flex;position:fixed;top:0;left:220px;right:0;box-shadow:0 1px 4px #0000001a}.header-left{align-items:center;gap:16px;display:flex}.header-logo{color:#1890ff;align-items:center;gap:12px;font-size:18px;font-weight:700;display:flex}.header-right{align-items:center;gap:24px;display:flex}.header-center{flex:1;min-width:300px;margin:0 24px}.announcement-scroll{background:#f0f7ff;border-radius:4px;align-items:center;height:24px;padding:4px 12px;display:flex;overflow:hidden}.announcement-content{white-space:nowrap;animation:20s linear infinite scroll-left;display:flex}.announcement-item{color:#1890ff;padding:0 24px;font-size:14px}@keyframes scroll-left{0%{transform:translate(100%)}to{transform:translate(-100%)}}.announcement-content:hover{animation-play-state:paused}.main-sider{z-index:100;background:#001529;flex-direction:column;height:100vh;transition:all .2s;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.main-sider .ant-menu{flex:1;overflow-y:auto;height:auto!important;margin:0!important;padding:0!important}.main-sider .ant-btn{background:#ffffff1a;border-radius:0;width:100%;height:40px;transition:all .2s;margin:0!important}.main-sider .ant-btn:hover{color:#fff!important;background:#fff3!important}.main-sider .ant-menu-submenu-title{font-weight:500;color:#fffffff2!important;align-items:center!important;height:48px!important;line-height:48px!important;display:flex!important}.main-sider .ant-menu-item{font-weight:500;color:#fffffff2!important;align-items:center!important;height:48px!important;padding-left:24px!important;padding-right:24px!important;line-height:48px!important;display:flex!important}.main-sider .ant-menu-submenu-title>span,.main-sider .ant-menu-item>span{align-items:center!important;gap:12px!important;display:flex!important}.main-sider .ant-menu-item-icon,.main-sider .ant-menu-submenu-icon{flex-shrink:0;justify-content:center!important;align-items:center!important;width:16px!important;height:16px!important;font-size:16px!important;display:flex!important}.main-sider .ant-menu-title-content{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden;font-size:14px!important}.main-sider .ant-menu-sub .ant-menu-item{font-size:13px;color:#ffffffa6!important;height:40px!important;padding-left:48px!important;line-height:40px!important}.main-sider .ant-menu-sub .ant-menu-item:hover,.main-sider .ant-menu-sub .ant-menu-item-active,.main-sider .ant-menu-sub .ant-menu-item-selected{color:#1890ff!important;background:#1890ff26!important}.main-content-wrapper{will-change:margin-left;background:#f0f2f5;width:100%;min-height:100vh;margin-left:220px;padding-top:50px;transition:margin-left .3s ease-in-out;display:flex}.main-layout .ant-layout-sider-collapsed+.main-content-wrapper{margin-left:80px}.main-content{flex:1;min-width:0;padding:24px;transition:all .3s ease-in-out;overflow:auto}.right-sidebar{background:#fff;border-left:1px solid #e8e8e8;flex-shrink:0;width:200px;padding:12px}.top-sidebar{background:#fff;border-radius:8px;margin-bottom:12px;padding:8px;box-shadow:0 1px 4px #0000000d}.top-sidebar-content{width:100%;max-width:1200px;margin:0 auto}.top-sidebar-section{margin-bottom:8px}.top-sidebar-section h4{color:#333;border-left:3px solid #1890ff;margin-bottom:4px;padding-left:6px;font-size:13px;line-height:1}.quick-entry-container{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.quick-entry-actions{text-align:right;flex:1;min-width:240px}.quick-entry-item{cursor:pointer;text-align:center;border-radius:4px;flex-direction:column;align-items:center;gap:2px;width:70px;padding:6px;transition:all .3s;display:flex}.quick-entry-item span{color:#333;font-size:11px;line-height:1}.top-sidebar-row{flex-wrap:wrap;gap:24px;display:flex}.weather-section{flex:0 0 200px}.notice-section{flex:0 0 300px}.top-sidebar-section:nth-child(3){flex:1;min-width:300px}.top-sidebar .weather-widget{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:8px;align-items:center;gap:12px;padding:16px;display:flex}.top-sidebar .weather-icon{font-size:32px}.top-sidebar .weather-info h5{margin:0 0 4px;font-size:14px}.top-sidebar .weather-info p{margin:0;font-size:20px;font-weight:700}.top-sidebar .notice-list{max-height:100px;overflow-y:auto}.top-sidebar .notice-item{border-bottom:1px solid #f0f0f0;padding:8px 0;font-size:12px}.top-sidebar .notice-item:last-child{border-bottom:none}.top-sidebar .notice-item .title{color:#333;text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px;overflow:hidden}.top-sidebar .notice-item .time{color:#999;font-size:11px}.sidebar-section{margin-bottom:24px}.sidebar-section h4{color:#333;border-left:3px solid #1890ff;margin-bottom:12px;padding-left:8px;font-size:14px}.page-header{margin-bottom:12px}.page-header h2{color:#333;margin:0;font-size:18px}.page-content{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 4px #0000000d}.table-toolbar{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.table-toolbar-left,.table-toolbar-right{gap:8px;display:flex}.status-tag{align-items:center;gap:4px;display:inline-flex}.quick-entry-item{cursor:pointer;border-radius:6px;align-items:center;gap:8px;margin-bottom:8px;padding:10px 12px;transition:all .3s;display:flex}.quick-entry-item:hover{background:#f0f7ff}.quick-entry-item .icon{border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.notice-list{max-height:200px;overflow-y:auto}.notice-item{border-bottom:1px solid #f0f0f0;padding:8px 0;font-size:13px}.notice-item:last-child{border-bottom:none}.notice-item .title{color:#333;text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px;overflow:hidden}.notice-item .time{color:#999;font-size:12px}.weather-widget{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:8px;align-items:center;gap:12px;padding:16px;display:flex}.weather-icon{font-size:40px}.weather-info h5{margin:0 0 4px;font-size:16px}.weather-info p{margin:0;font-size:24px;font-weight:700}.sample-status{border-radius:12px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;display:inline-flex}.sample-status.pending{color:#fa8c16;background:#fff7e6}.sample-status.testing{color:#1890ff;background:#e6f7ff}.sample-status.completed{color:#52c41a;background:#f6ffed}.sample-status.abnormal{color:#f5222d;background:#fff1f0}.e-signature{color:#1890ff;align-items:center;gap:4px;font-size:12px;display:inline-flex}@media (width<=1200px){.right-sidebar{display:none}.main-header{left:80px}.main-content-wrapper{margin-left:80px}.main-sider{width:80px!important}.main-sider .ant-menu-item{text-align:center}.main-sider.ant-layout-sider-collapsed .ant-menu-item span,.main-sider.ant-layout-sider-collapsed .ant-menu-submenu-title span{display:none}.top-sidebar-row{flex-direction:column;gap:16px}.weather-section,.notice-section{flex:none;width:100%}.top-sidebar-section:nth-child(3){min-width:100%}.quick-entry-container{justify-content:flex-start}}@media (width<=768px){.login-box{max-width:none;margin:16px;padding:24px}.login-header{padding:12px 16px}.login-header-right{gap:12px}.main-sider{z-index:1000;width:64px!important}.main-header{height:44px;padding:6px 12px;left:64px}.main-content-wrapper{margin-left:64px;padding-top:44px}.main-content{padding:12px}.main-sider .ant-menu-item{margin:4px 0!important;padding:12px 8px!important}.main-sider.ant-layout-sider-collapsed .ant-menu-item span,.main-sider.ant-layout-sider-collapsed .ant-menu-submenu-title span{display:none}.header-logo{font-size:14px}.header-logo svg{width:24px;height:24px}.header-center{display:none}.header-right{gap:8px}.page-content{padding:12px}.table-toolbar{flex-direction:column;align-items:stretch;gap:12px}.table-toolbar-left,.table-toolbar-right{flex-wrap:wrap}.custom-table .ant-table-thead>tr>th{height:36px!important;padding:8px 4px!important;font-size:11px!important}.custom-table .ant-table-tbody>tr>td{height:40px!important;padding:8px 4px!important;font-size:11px!important}.ant-table{font-size:11px}.ant-btn{height:auto;padding:4px 8px;font-size:12px;line-height:1.5}.ant-input{height:32px;font-size:12px}.ant-select-selector{height:32px!important;font-size:12px!important}.ant-modal{max-width:calc(100% - 16px);margin:8px}.ant-modal-header{padding:12px}.ant-modal-title{font-size:14px}.ant-modal-body{padding:12px}.ant-drawer{max-width:360px;width:90%!important}.top-sidebar{display:none}.quick-entry-item{width:60px}.quick-entry-item .icon{width:24px;height:24px;font-size:12px}.quick-entry-item span{font-size:10px}.sample-status{padding:2px 8px;font-size:10px}.login-title h1{font-size:22px}.login-title p{font-size:12px}}@media (width<=480px){.login-box,.login-main{padding:16px}.main-sider{width:56px!important}.main-header{left:56px}.main-content-wrapper{margin-left:56px}.main-content{padding:8px}.page-content{border-radius:4px;padding:8px}.ant-space{flex-wrap:wrap}.ant-space-item{flex:1;min-width:calc(50% - 4px)}.ant-btn{justify-content:center;width:100%}.custom-table{min-width:600px}.ant-table-body{overflow-x:auto}.ant-form-item-label{padding-bottom:4px!important}.ant-form-item-label>label{font-size:12px}.ant-form-item-control-input-content{min-height:32px}.ant-date-picker,.ant-picker{width:100%}.ant-picker-input input{font-size:12px}}@media (hover:none){.quick-entry-item:active{background:#e6f7ff}.main-sider .ant-menu-item:active{background:#1890ff33!important}.ant-btn:active{transform:scale(.98)}}.custom-table .ant-table-thead>tr>th{color:#333!important;background:#fafafa!important;border-bottom:2px solid #e8e8e8!important;height:48px!important;padding:12px 16px!important;font-size:13px!important;font-weight:600!important;line-height:24px!important}.custom-table .ant-table-tbody>tr>td{color:#333!important;vertical-align:middle!important;border-bottom:1px solid #f0f0f0!important;height:54px!important;padding:12px 16px!important;font-size:13px!important;line-height:20px!important}.custom-table .ant-table-tbody>tr:hover>td{background:#fafafa!important}.custom-table .ant-table-tbody>tr{transition:background .2s!important}.custom-table .ant-table-cell-fix-left,.custom-table .ant-table-cell-fix-right{z-index:1!important;background:#fff!important}.custom-table .ant-table-thead>tr>th.ant-table-cell-fix-left,.custom-table .ant-table-thead>tr>th.ant-table-cell-fix-right{z-index:2!important;background:#fafafa!important}.custom-table .ant-table-body::-webkit-scrollbar{width:8px;height:8px}.custom-table .ant-table-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.custom-table .ant-table-body::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.custom-table .ant-table-body::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.custom-table .ant-checkbox-wrapper{justify-content:center;align-items:center;display:flex}
