:root{font-family:Inter,Segoe UI,Microsoft YaHei,Arial,sans-serif;color:#172033;background:#f4f6f9;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0}.shell{min-height:100vh;background:#f4f6f9}.auth-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:#f4f6f9}.auth-panel{width:min(520px,100%);padding:28px;background:#fff;border:1px solid #d9e2ef;border-top:6px solid #1f6feb;box-shadow:0 18px 48px #10233f1f}.auth-brand{margin-bottom:24px;color:#10233f}.auth-actions{display:flex;justify-content:flex-end}.auth-demo{display:grid;gap:6px;margin-top:18px;padding:12px;color:#637085;background:#f7f9fc;border:1px solid #d9e2ef;font-size:13px}.authz-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px;padding:12px 14px;background:#f7f9fc;border:1px solid #d9e2ef}.authz-head span{color:#637085;font-size:13px}.authz-bind{display:grid;grid-template-columns:110px minmax(240px,360px);align-items:center;gap:10px;margin-bottom:14px}.authz-bind label{color:#10233f;font-weight:700}.account-permission-layout{display:grid;gap:14px}.notice-menu-alert,.notice-tab-alert{color:#ff6b6b;animation:noticePulse 1.2s ease-in-out infinite}@keyframes noticePulse{0%,to{opacity:1}50%{opacity:.35}}.sidebar{background:#10233f;color:#fff;box-shadow:8px 0 24px #10233f29}.brand{display:flex;align-items:center;gap:12px;min-height:72px;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.12)}.brand strong{display:block;font-size:17px;letter-spacing:0}.brand span{display:block;margin-top:3px;color:#aebed4;font-size:12px}.seal{display:grid;place-items:center;width:40px;height:40px;flex:0 0 40px;border:2px solid #ffffff;border-radius:50%;background:#b31942;color:#fff;font-weight:800;font-size:12px}.menu-scroll{height:calc(100vh - 72px)}.el-menu{border-right:0}.el-menu-item.is-active{background:#1f6feb!important}.el-menu-item-group__title{color:#8ea2bd;font-size:12px}.topbar{height:72px;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:0 24px;background:#fff;border-bottom:1px solid #d9e2ef}.topbar-left,.topbar-right{display:flex;align-items:center;gap:14px;min-width:0}.topbar h1{margin:0;font-size:20px;font-weight:760;color:#10233f}.section-icon{width:36px;height:36px;padding:8px;background:#e8f1fd;color:#1f6feb;border-radius:4px}.topbar p{margin:4px 0 0;color:#637085;font-size:13px}.role-select{width:190px}.notice-badge{line-height:1}.data-table .el-table__cell .cell,.registry-table .el-table__cell .cell{white-space:nowrap}.notification-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;color:#4d5b70}.notification-list{display:grid;gap:10px}.notification-item{width:100%;display:grid;gap:6px;padding:12px;text-align:left;border:1px solid #d9e2ef;border-left:4px solid #8ea2bd;border-radius:6px;background:#fff;color:#10233f;cursor:pointer}.notification-item.unread{border-left-color:#1f6feb;background:#f5f9ff}.notification-item.urgent{border-left-color:#d92d20}.notification-item strong{font-size:14px}.notification-item span:last-child{color:#637085;font-size:13px;line-height:1.45}.notification-meta{display:flex;align-items:center;justify-content:space-between;gap:10px}.notification-meta em{color:#8ea2bd;font-size:12px;font-style:normal}.content{min-width:0;padding:22px}.page-stack{display:grid;gap:18px}.hero-band{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:150px;padding:28px 30px;background:linear-gradient(90deg,#10233f,#1f6feb);color:#fff;border-bottom:5px solid #b31942}.dashboard-filter{grid-template-columns:repeat(4,minmax(150px,1fr)) auto}.chart-grid{display:grid;grid-template-columns:repeat(2,minmax(320px,1fr));gap:18px}.chart-panel{min-height:320px;padding:22px;background:#fff;border:1px solid #d9e2ef}.chart-title{margin-bottom:20px;color:#10233f;font-weight:700}.bar-chart{height:210px;display:flex;align-items:end;justify-content:space-around;gap:14px;padding:14px 12px 34px;border-left:1px solid #d9e2ef;border-bottom:1px solid #d9e2ef;background:repeating-linear-gradient(to top,#fff,#fff 23px,#edf2f8 24px)}.bar-item{position:relative;display:flex;align-items:end;gap:3px;height:160px}.bar-item em{position:absolute;left:50%;bottom:-30px;transform:translate(-50%) rotate(-45deg);color:#637085;font-size:11px;font-style:normal;white-space:nowrap}.bar{width:14px;min-height:6px}.cyan,.dot.cyan{background:#3fd1df}.blue,.dot.blue{background:#1685d9}.legend{margin-top:18px;text-align:center;color:#41506a}.dot{display:inline-block;width:12px;height:12px;margin:0 6px 0 16px;border-radius:50%;vertical-align:-1px}.pie-wrap{min-height:230px;display:flex;align-items:center;justify-content:center;gap:28px}.pie{width:170px;height:170px;border-radius:50%;background:conic-gradient(#f7c52b 0,#f7c52b 5.9%,#1685d9 5.9%,#1685d9)}.hero-band h2{margin:0;font-size:30px;letter-spacing:0}.hero-band p{max-width:760px;margin:10px 0 0;color:#e7eef8;line-height:1.7}.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:14px}.stat{padding:18px;background:#fff;border:1px solid #d9e2ef;border-left:5px solid #1f6feb}.stat.accent{border-left-color:#b31942}.stat.green{border-left-color:#2e8540}.stat.red{border-left-color:#d83933}.stat span,.stat small{display:block;color:#637085}.stat strong{display:block;margin:8px 0;color:#10233f;font-size:30px}.two-col{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(360px,.65fr);gap:18px}.panel{min-width:0;padding:18px;background:#fff;border:1px solid #d9e2ef}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px}.panel-head h3{margin:0;color:#10233f;font-size:18px}.head-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.filterbar{display:grid;grid-template-columns:repeat(5,minmax(150px,1fr)) auto auto;gap:10px;align-items:center;margin-bottom:16px;padding:14px;background:#f7f9fc;border:1px solid #dfe7f2}.filterbar .el-date-editor{width:100%}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:4px 18px}.form-grid .wide{grid-column:1 / -1}.registration-grid{grid-template-columns:repeat(4,minmax(220px,1fr));gap:0;border-top:1px solid #d9e2ef;border-left:1px solid #d9e2ef}.registration-grid .el-form-item{min-height:58px;margin:0;padding:12px;border-right:1px solid #d9e2ef;border-bottom:1px solid #d9e2ef}.registration-grid .wide{grid-column:1 / -1}.registration-grid .upload-cell{min-height:92px;align-items:center}.registration-grid .avatar-cell{grid-row:span 2;background:#e8f1fd}.form-grid .el-select,.form-grid .el-date-editor,.form-grid .el-input-number{width:100%}.inline-tip{margin-left:10px;color:#637085;font-size:13px}.course-picker{margin-top:14px;padding-top:14px;border-top:1px solid #d9e2ef}.training-select-block{width:100%}.training-select-block .inline-filter,.course-picker .inline-filter{margin-bottom:12px}.training-select-block .el-transfer{width:100%}.selected-driver-strip{display:flex;flex-wrap:wrap;gap:10px;min-height:74px;margin-top:12px;padding:12px;background:#f7f9fc;border:1px dashed #aebed4}.selected-driver-strip em{align-self:center;color:#637085;font-style:normal}.driver-avatar-card{display:grid;grid-template-columns:38px auto;grid-template-rows:auto auto;gap:0 8px;align-items:center;min-width:148px;padding:8px 10px;background:#fff;border:1px solid #d9e2ef}.driver-avatar-card span{display:grid;grid-row:1 / 3;place-items:center;width:38px;height:38px;color:#fff;background:#1f6feb;border-radius:50%;font-weight:700}.driver-avatar-card strong{color:#10233f;font-size:14px}.driver-avatar-card small{color:#637085}.actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.empty-state{margin-bottom:16px;padding:28px;background:#f7f9fc;border:1px dashed #aebed4}.empty-state h2{margin:0 0 8px;color:#10233f}.empty-state p{margin:0;color:#637085}.requirement-plan{display:grid;gap:14px}.plan-steps{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:12px}.plan-steps div{display:grid;gap:6px;padding:14px;background:#fff;border:1px solid #d9e2ef}.plan-steps strong{color:#10233f}.plan-steps span,.template-preview{color:#4b5b70;line-height:1.7;white-space:pre-line}.plan-section-list{display:grid;gap:12px}.plan-section{padding:16px;background:#fff;border:1px solid #d9e2ef}.plan-section h4{margin:0 0 10px;color:#10233f;font-size:16px}.plan-section p{margin:0 0 8px;color:#334155;line-height:1.8}.plan-section p:last-child{margin-bottom:0}.driver-tabs{margin-top:16px}.driver-web-block{min-height:calc(100vh - 112px);display:grid;place-items:center}.driver-lock-panel{width:min(880px,100%);padding:34px;background:#fff;border:1px solid #d9e2ef;box-shadow:0 18px 40px #10233f1a}.driver-lock-panel h2{margin:0 0 10px;color:#10233f;font-size:26px}.driver-lock-panel p{margin:0 0 22px;color:#4b5b70;line-height:1.7}.driver-cap-grid{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:10px;margin-bottom:22px}.driver-cap-grid span{padding:10px 12px;background:#edf4fc;color:#1a4480;border:1px solid #cbd8e8;font-weight:700;text-align:center}.progress-detail{display:grid;gap:14px}.detail-filter{grid-template-columns:100px 220px 150px 150px repeat(5,auto)}.sheet-form{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));border-top:1px solid #d9e2ef;border-left:1px solid #d9e2ef}.sheet-row{display:grid;grid-template-columns:170px minmax(0,1fr);align-items:center;min-height:56px;border-right:1px solid #d9e2ef;border-bottom:1px solid #d9e2ef}.sheet-row.full{grid-column:1 / -1}.sheet-row label{align-self:stretch;display:flex;align-items:center;padding:10px 12px;background:#f7f9fc;color:#10233f;font-weight:600}.sheet-row label.required:before{content:"*";margin-right:2px;color:#d83933}.sheet-row>.el-input,.sheet-row>.el-select,.sheet-row>.el-date-editor,.sheet-row>.el-upload,.sheet-row>div:not(.certificate-list):not(.input-with-button):not(.inline-controls){margin:8px;width:calc(100% - 16px)}.sheet-row>span{padding:0 12px}.sheet-row small{color:#d83933;font-weight:500}.import-error-lines{max-height:120px;overflow:auto}.import-error-lines p{margin:4px 0 0;line-height:1.5}.input-with-button,.inline-controls{display:flex;gap:8px;align-items:center;margin:8px;width:calc(100% - 16px)}.input-with-button .el-input{flex:1}.registry-inline-search{width:100%;margin:0}.registry-inline-search .plate-input{flex:1}.xunfa-lookup{display:grid;gap:12px}.inline-controls .el-select{width:180px}.section-title-row{display:flex;justify-content:center;min-height:72px;font-size:22px;color:#10233f;background:#fff}.plus-upload{display:grid;place-items:center;width:130px;height:110px;margin:16px;border:2px dashed #1f6feb;color:#1f6feb;font-size:36px;border-radius:8px}.plus-upload span{font-size:16px;font-weight:800}.uploaded-file-name{display:inline-block;max-width:360px;margin-left:12px;color:#4b5b70;overflow:hidden;text-overflow:ellipsis;vertical-align:middle;white-space:nowrap}.narrow-sheet{max-width:760px;margin:0 auto}.full-check{border-right:1px solid #d9e2ef}.report-sheet{display:grid;gap:16px}.report-sheet h2{margin:0;text-align:center;color:#10233f;font-weight:500}.report-sheet table{width:100%;border-collapse:collapse}.report-sheet th,.report-sheet td{padding:12px;border:1px solid #d9e2ef;vertical-align:top;text-align:left}.report-sheet th{width:110px;background:#f7f9fc;color:#10233f}.report-sheet tr:nth-child(2n) td,.report-sheet tr:nth-child(2n) th{background:#e8f1fd}.report-sheet p{margin:0 0 6px}.photo-row{display:flex;gap:4px}.photo-row span{width:34px;height:34px;background:linear-gradient(135deg,#26384f,#b8c7d9)}.signature{height:70px;color:#3d4c60;font-size:32px;font-style:italic}.course-preview{display:grid;gap:16px}.course-preview h3{margin:0;color:#10233f}.preview-box{display:grid;place-items:center;min-height:240px;background:#10233f;color:#fff;border:1px solid #d9e2ef}.plan-detail,.daily-template-detail{display:grid;gap:16px}.driver-training-detail{min-height:480px}.verify-layout{display:grid;gap:18px}.verify-main-photo,.verify-photo{display:grid;place-items:center;width:104px;height:124px;border:1px solid #b7c6d8;background:#eef4fb;color:#1a4480;font-weight:700}.signature-card{display:grid;gap:8px;width:190px;padding:14px;border:1px solid #d9e2ef;background:#fff}.signature-card strong{font-size:28px;color:#10233f;font-family:STKaiti,KaiTi,serif}.verify-grid{display:grid;grid-template-columns:repeat(5,132px);gap:28px}.verify-photo{width:132px;height:104px}.verify-photo span{align-self:end}.verify-photo strong{align-self:start;color:#10233f}.risk-card{display:grid;gap:16px;padding:18px;border:4px solid #d83933;background:#fff8f8}.risk-card h2{margin:0;text-align:center;color:#10233f}.risk-level{justify-self:center;padding:10px 34px;background:#d83933;color:#fff;font-size:22px;font-weight:800}.certificate-row{min-height:120px}.certificate-list{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));gap:18px;padding:14px}.certificate-list .el-button{width:100%;min-height:74px;background:#afc2dc;color:#003b8f}.daily-template-form{display:block}.check-section{padding:16px;border-right:1px solid #d9e2ef;border-bottom:1px solid #d9e2ef}.check-section h4{margin:0 0 12px;color:#10233f}.check-grid{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:10px}.standard-layout{display:grid;grid-template-columns:300px minmax(0,1fr);gap:22px}.standard-types{min-height:620px;padding:12px;background:#fff;border:1px solid #d9e2ef}.standard-types h3{margin:0 0 12px;padding:0 0 10px;text-align:center;color:#10233f;border-bottom:1px solid #d9e2ef}.standard-types button{display:block;width:100%;padding:12px 18px;border:0;background:transparent;color:#10233f;text-align:left;font:inherit;cursor:pointer}.standard-types button.active{background:#0b6bdc;color:#fff;font-weight:700}.standard-panel{min-height:620px}.inline-filter{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:16px}.inline-filter .el-input{width:220px}.inline-filter .el-select{width:150px}.course-library{display:grid;grid-template-columns:280px minmax(0,1fr);gap:18px}.course-tree,.course-table-panel{min-height:560px;background:#fff;border:1px solid #d9e2ef}.course-tree{padding:12px}.tree-title{padding:0 0 10px;margin-bottom:10px;color:#10233f;font-weight:800;border-bottom:1px solid #d9e2ef}.tree-node{display:inline-flex;align-items:center;width:100%;min-width:0;gap:8px}.tree-node span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-node em{margin-left:auto;padding:1px 6px;border-radius:999px;background:#e7eef8;color:#1a4480;font-style:normal;font-size:12px}.course-table-panel{padding:14px}.course-path{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;color:#4b5b70}.course-path strong{color:#10233f}.registry-page{display:grid;gap:12px;min-width:0}.registry-filter{grid-template-columns:auto minmax(180px,240px) repeat(5,auto);justify-content:start;margin-bottom:0}.company-registry-filter{display:flex;flex-wrap:wrap;grid-template-columns:none;justify-content:flex-start}.registry-filter>span,.registry-filter-field>span{color:#10233f;font-weight:700;white-space:nowrap}.registry-filter-field{display:grid;grid-template-columns:auto minmax(140px,190px);align-items:center;gap:8px}.registry-filter-field-wide{grid-template-columns:auto minmax(160px,220px)}.registry-filter-field .el-input,.registry-filter-field .el-select,.registry-filter-field .el-cascader{width:100%}.registry-table{width:100%;max-width:100%;border:1px solid #d9e2ef}.expired-date{display:inline-block;padding:2px 8px;color:#ff4d4f;background:#fff1f0;border:1px solid #ffccc7;border-radius:4px}.registry-form{display:grid;gap:12px}.registry-section-title{width:fit-content;padding:8px 12px;color:#10233f;background:#f4f6f9;border-radius:4px;font-weight:800}.registry-section-title.sub{margin-top:4px;font-size:15px}.registry-form-grid{display:grid;grid-template-columns:repeat(2,minmax(320px,1fr));gap:14px 46px;padding:6px 8px 18px}.certificate-grid{padding:10px 0 16px;border:1px solid #d9e2ef;border-radius:4px}.registry-field{display:grid;grid-template-columns:120px minmax(0,1fr);align-items:center;gap:10px;min-height:42px}.registry-field.wide{grid-column:1 / -1}.registry-field.upload-field{align-items:start}.registry-field>label{color:#10233f;text-align:right;font-weight:600}.registry-field>label.required:before{content:"*";margin-right:3px;color:#d83933}.plate-input{display:grid;grid-template-columns:78px 1fr}.plate-input .el-select .el-select__wrapper{border-radius:4px 0 0 4px}.plate-input .el-input__wrapper{border-radius:0 4px 4px 0}.upload-tile{display:inline-grid;gap:6px;justify-items:center;width:138px}.upload-tile .el-upload{width:138px;height:126px}.upload-tile img,.upload-placeholder{display:grid;place-items:center;width:138px;height:126px;object-fit:cover;background:#f7f9fc;border:1px dashed #b7c6d8;border-radius:6px}.upload-placeholder{color:#8c96a6;font-size:42px;line-height:1}.upload-tile-preview,.preview-link{padding:0;border:0;background:transparent;color:#0b63ce;cursor:pointer;font:inherit}.upload-preview-dialog{display:grid;place-items:center;gap:12px;min-height:360px;padding:12px;background:#f7f9fc;border:1px solid #d9e2ef}.upload-preview-dialog img{max-width:100%;max-height:70vh;object-fit:contain}.upload-preview-dialog iframe{width:100%;min-height:70vh;border:0;background:#fff}.preview-actions{justify-self:end}.registry-detail{display:grid;gap:14px}.registry-detail h3{margin:0;color:#10233f;font-size:16px}.registry-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));border-top:1px solid #d9e2ef;border-left:1px solid #d9e2ef}.registry-detail-grid>div{display:grid;grid-template-columns:170px minmax(0,1fr);min-height:42px;border-right:1px solid #d9e2ef;border-bottom:1px solid #d9e2ef}.registry-detail-grid>div.wide{grid-column:1 / -1}.registry-detail-grid label{display:flex;align-items:center;padding:10px;background:#f7f9fc;color:#10233f;font-weight:700}.registry-detail-grid span,.registry-detail-grid button{align-self:center;margin:0 10px}.el-button,.el-input__wrapper,.el-select__wrapper,.el-textarea__inner{border-radius:4px}@media(max-width:1180px){.stat-grid,.two-col,.chart-grid,.form-grid{grid-template-columns:1fr}.filterbar{grid-template-columns:repeat(2,minmax(150px,1fr))}.course-library,.standard-layout,.plan-steps,.registry-form-grid,.registry-detail-grid{grid-template-columns:1fr}.registry-filter,.company-registry-filter{grid-template-columns:1fr 1fr}}@media(max-width:760px){.topbar{height:auto;align-items:flex-start;flex-direction:column;padding:14px}.topbar-right{width:100%;justify-content:space-between}.content{padding:14px}.hero-band{align-items:flex-start;flex-direction:column}.hero-band h2{font-size:24px}.filterbar{grid-template-columns:1fr}}
