*{box-sizing:border-box}body{margin:0;font-family:Microsoft YaHei,sans-serif;background:#f5f7fa}#app,.login-wrap{min-height:100vh}.login-wrap{display:grid;grid-template-columns:minmax(520px,1.18fr) minmax(420px,.82fr);background:#eef2f7;overflow:hidden}.login-brand-panel{position:relative;display:flex;align-items:center;justify-content:center;min-height:100vh;color:#fff;background:#061527}.login-brand-panel:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,rgba(50,134,230,.82) 0 2px,transparent 2.5px),radial-gradient(circle,rgba(50,134,230,.5) 0 1.5px,transparent 2px);background-size:180px 180px,96px 96px;background-position:108px 118px,20px 58px;opacity:.75}.login-brand-panel:after{content:"";position:absolute;left:0;right:0;top:56%;height:1px;background:linear-gradient(90deg,transparent,rgba(55,132,220,.55),transparent)}.brand-center{position:relative;z-index:1;width:min(520px,78%);text-align:center}.brand-emblem{width:112px;height:112px;margin:0 auto 22px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(28,91,175,.16);box-shadow:0 0 0 12px rgba(35,101,191,.08),inset 0 0 28px rgba(48,128,226,.16)}.brand-emblem span{width:42px;height:42px;display:block;border:2px solid #2f80ed;border-radius:10px;transform:rotate(45deg);position:relative;box-shadow:0 0 18px rgba(47,128,237,.55)}.brand-emblem span:after{content:"";position:absolute;inset:9px;border:2px solid hsla(0,0%,100%,.35);border-radius:7px}.brand-center h1{margin:0;font-size:42px;line-height:1.18;font-weight:800;text-shadow:0 4px 0 rgba(0,0,0,.22)}.brand-subtitle{margin-top:8px;color:rgba(218,230,247,.72);font-family:Georgia,Times New Roman,serif;font-size:13px;font-weight:700;letter-spacing:8px}.brand-divider{height:1px;margin:14px 0 20px;background:linear-gradient(90deg,transparent,rgba(63,139,234,.7),transparent)}.brand-features{display:flex;justify-content:center;gap:74px}.brand-feature{width:74px;color:rgba(227,239,255,.88);font-size:12px}.brand-feature p{margin:10px 0 0;white-space:nowrap}.feature-icon{width:42px;height:42px;margin:0 auto;border:1px solid rgba(90,151,229,.52);border-radius:9px;color:#2f80ed;background:rgba(17,39,72,.78);box-shadow:inset 0 0 16px rgba(64,132,224,.12);font-size:13px;font-weight:700}.feature-icon,.login-form-panel{display:flex;align-items:center;justify-content:center}.login-form-panel{min-height:100vh;padding:48px;background:#e9eef4}.login-card{width:min(390px,100%);background:transparent;border-radius:0;padding:0;box-shadow:none}.login-card h2{margin:0;color:#071323;font-size:30px;line-height:1.2;font-weight:800}.login-subtitle{margin:8px 0 34px;color:#77869a;font-size:14px}.login-state{min-height:44px;display:flex;align-items:center;margin-bottom:26px;padding:0 16px;border:1px solid #a9dcd8;border-radius:8px;color:#08786d;background:#d8efed;font-size:14px;font-weight:700}.login-state.error{color:#b42318;border-color:#f5b5ad;background:#fff0ee}.login-field{margin-bottom:24px}.login-field label{display:block;margin-bottom:12px;color:#0d1b2f;font-size:14px;font-weight:700}.login-field input{width:100%;height:42px;padding:0;border:0;border-bottom:2px solid #c7d1de;border-radius:0;background:transparent;color:#081425;font-size:16px;font-weight:700;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.login-field input::-moz-placeholder{color:#9aa7b7;font-weight:500}.login-field input::placeholder{color:#9aa7b7;font-weight:500}.login-field input:focus{border-bottom-color:#3478db;box-shadow:0 8px 0 -7px rgba(52,120,219,.22)}.login-button{width:100%;height:46px;margin-top:2px;border:0;border-radius:5px;background:#3474d9;color:#fff;font-size:16px;font-weight:800;box-shadow:0 12px 24px rgba(52,116,217,.18);transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.login-button:hover{background:#2868cc;box-shadow:0 16px 30px rgba(52,116,217,.24);transform:translateY(-1px)}.login-button:disabled{cursor:not-allowed;opacity:.72;transform:none;box-shadow:none}.form-item{margin-bottom:14px}.form-item label{display:block;margin-bottom:6px;color:#555}button,input,select{height:34px;border:1px solid #d9d9d9;border-radius:4px;padding:0 10px}input,select{width:100%}button{cursor:pointer;background:#fff}button.primary{background:#1677ff;border-color:#1677ff}button.danger{color:#cf1322;border-color:#ffccc7}.error{color:#cf1322;margin-top:10px}.layout{display:flex;min-height:100vh}.sidebar{width:220px;background:#001529;color:#fff;padding:16px 0}.brand{font-size:18px;font-weight:600;padding:0 20px 18px;border-bottom:1px solid hsla(0,0%,100%,.15);margin-bottom:8px}.menu{padding:12px 20px;cursor:pointer}.menu.active,.menu:hover{background:#1677ff}.content{flex:1;padding:16px}.topbar{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-radius:6px;margin-bottom:16px}.panel,.topbar{background:#fff}.panel{padding:16px;animation:panelFade .28s ease}.toolbar{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));margin-bottom:12px}.form-grid{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:10px}.part-grid{grid-template-columns:repeat(3,minmax(120px,1fr))}table{width:100%;border-collapse:collapse}td,th{border:1px solid #f0f0f0;padding:8px;text-align:left;font-size:14px}.part-thumb{width:48px;height:48px;display:block;-o-object-fit:cover;object-fit:cover;border-radius:6px;border:1px solid #e5e7eb;background:#f8fafc}.modal-mask{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:999}.modal{width:520px;background:#fff;padding:16px;box-shadow:0 18px 44px rgba(19,38,77,.22);animation:modalIn .24s ease}.modal-wide{width:720px}.modal h4{margin:0 0 14px}.modal-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px}.modal-form-item{display:flex;align-items:center;margin-bottom:10px}.modal-form-full{grid-column:1/-1;align-items:flex-start}.modal-form-item label{width:88px;flex:0 0 88px;color:#333}.modal-form-item input,.modal-form-item select{flex:1;width:auto}.readonly-text{flex:1;min-height:36px;display:flex;align-items:center;color:#36527a}.category-picker-item{align-items:flex-start}.category-picker{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px}.category-picker-level{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.category-picker-level span{width:42px;flex:0 0 42px;color:#36527a;font-size:13px;font-weight:700}.category-picker-level button{height:30px;padding:0 12px;border-color:#dbe5f2;background:#f8fbff;color:#36527a;font-size:13px}.category-picker-level button.active{border-color:#8db5ff;color:#2f6fd6;background:#eef5ff}.category-picker-level button.selected{border-color:#3b7cff;color:#fff;background:#3b7cff}.category-picked{padding-left:42px;color:#667085;font-size:13px}.image-picker{flex:1;min-width:0;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.upload-button{position:relative;width:auto!important;flex:0 0 auto!important;height:34px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #1677ff;border-radius:4px;color:#1677ff;background:#eef6ff;cursor:pointer;font-size:14px}.upload-button input{position:absolute;inset:0;opacity:0;cursor:pointer}.upload-name{color:#667085;font-size:13px}.image-preview{width:76px;height:76px;-o-object-fit:cover;object-fit:cover;border-radius:7px;border:1px solid #e4e7ec;background:#f8fafc}.clickable-thumb{cursor:zoom-in}.image-preview-mask{z-index:1300}.image-preview-modal{position:relative;max-width:min(920px,92vw);max-height:88vh}.image-preview-modal img{display:block;max-width:100%;max-height:88vh;-o-object-fit:contain;object-fit:contain;border-radius:8px;background:#fff;box-shadow:0 22px 60px rgba(0,0,0,.32)}.image-preview-close{position:absolute;right:-14px;top:-14px;width:34px;height:34px;border:0;border-radius:50%;background:#fff;color:#172231;font-size:24px;line-height:34px;box-shadow:0 8px 24px rgba(0,0,0,.22)}.modal-actions{margin-top:14px;display:flex;justify-content:flex-end;gap:10px}.notice{position:fixed;top:22px;right:22px;z-index:1200;min-width:260px;max-width:360px;padding:14px 16px;border-radius:10px;background:#fff;box-shadow:0 16px 34px rgba(0,0,0,.16);border-left:4px solid #1677ff}.notice.success{border-left-color:#16a34a}.notice.error{border-left-color:#dc2626}.notice-title{font-weight:600;margin-bottom:4px}.notice-text{color:#444;font-size:14px}.confirm-modal{width:420px}.confirm-text{margin:8px 0 16px;color:#333}.fade-pop-enter-active,.fade-pop-leave-active{transition:all .24s ease}.fade-pop-enter,.fade-pop-leave-to{opacity:0;transform:translateY(-8px) scale(.98)}@keyframes modalIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes panelFade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1200px){.form-grid,.part-grid,.toolbar{grid-template-columns:repeat(2,minmax(120px,1fr))}.modal-wide{width:92%}.modal-form-grid{grid-template-columns:1fr}}@media (max-width:900px){.login-wrap{grid-template-columns:1fr}.login-brand-panel{min-height:42vh;padding:48px 18px}.login-form-panel{min-height:58vh;padding:42px 24px;align-items:flex-start}.brand-center{width:min(420px,92%)}.brand-center h1{font-size:32px}.brand-subtitle{letter-spacing:4px}.brand-features{gap:28px}}@media (max-width:520px){.login-brand-panel{min-height:38vh}.brand-emblem{width:86px;height:86px;margin-bottom:16px}.brand-emblem span{width:34px;height:34px}.brand-center h1{font-size:28px}.brand-subtitle{font-size:11px;letter-spacing:2px}.brand-features{gap:16px}.brand-feature{width:62px}.feature-icon{width:38px;height:38px}.login-form-panel{padding:34px 22px}.login-card h2{font-size:26px}}body{color:#001b44;background:#eef3f8;font-size:14px}button,input,select,textarea{font-family:Microsoft YaHei,Arial,sans-serif;font-size:14px}.layout{background:#eef3f8}.sidebar{width:232px;background:#111827;padding:0;box-shadow:inset -1px 0 0 hsla(0,0%,100%,.06)}.brand{height:88px;display:flex;align-items:center;gap:12px;padding:0 14px;margin:0;border-bottom:1px solid hsla(0,0%,100%,.14)}.brand-mark{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:#3b7cff;font-size:13px}.brand-mark,.brand strong{color:#fff;font-weight:800;letter-spacing:0}.brand strong{font-size:18px}.brand small,.brand strong{display:block;line-height:1.2}.brand small{margin-top:4px;color:#a8bdd8;font-size:12px;font-weight:400}.menu{height:48px;margin:0 8px 2px;padding:0 16px;display:flex;align-items:center;gap:10px;border-radius:8px;color:#e8f1ff;font-size:15px;font-weight:700}.menu.active,.menu:hover{background:#1f2d42;color:#fff}.menu-icon{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;background:rgba(59,124,255,.16);color:#d8e8ff;font-size:13px;line-height:1}.menu.active .menu-icon,.menu:hover .menu-icon{background:#3b7cff;color:#fff}.content{padding:0 24px 24px;background:#eef3f8}.topbar{height:68px;margin:0 -24px 24px;padding:0 24px;border-radius:0;border-bottom:1px solid #e5ebf2;box-shadow:none}.page-title{color:#001b44;font-size:16px;font-weight:800}.topbar-user{display:flex;gap:12px;color:#36527a}.topbar-user,.user-pill{align-items:center;font-size:14px}.user-pill{height:42px;padding:0 18px;display:inline-flex;border:1px solid #dbe5f2;border-radius:22px;background:#f8fbff;color:#001b44;font-weight:700}.topbar button{width:auto;height:34px;border-color:#dbe5f2;color:#36527a;background:#fff;font-size:14px}.panel{padding:0;border:1px solid #e7edf4;border-radius:6px;box-shadow:0 1px 2px rgba(16,24,40,.03);overflow:hidden}.panel h3{height:50px;margin:0;padding:0 18px;display:flex;align-items:center;border-bottom:1px solid #e7edf4;color:#001b44;font-size:15px;font-weight:800}.panel p{padding:0 18px 18px;color:#36527a;font-size:14px}.stats-grid{padding:18px;display:grid;grid-template-columns:repeat(2,minmax(180px,260px));gap:14px}.stat-card{min-height:96px;padding:18px;border:1px solid #e7edf4;border-radius:6px;background:#f8fbff}.stat-card span{display:block;margin-bottom:12px;color:#36527a;font-size:14px;font-weight:700}.stat-card strong{color:#001b44;font-size:30px;line-height:1;font-weight:800}.toolbar{padding:18px;margin:0;border-bottom:1px solid #edf1f6;display:flex;flex-wrap:wrap;gap:10px;align-items:center}.toolbar input{width:170px;flex:0 0 170px}.toolbar select{width:150px;flex:0 0 150px}.toolbar button{flex:0 0 auto}input,select{background:#fff}button,input,select{height:36px;border-color:#dbe5f2;border-radius:6px;color:#001b44}button{width:auto;background:#f8fbff;font-weight:500}button.primary{background:#3b7cff;border-color:#3b7cff;color:#fff}button.danger{color:#dc2626;border-color:#ffd1d1;background:snow}.pagination{margin:0 18px 18px;display:flex;align-items:center;justify-content:flex-end;gap:10px;color:#36527a;font-size:14px}.pagination select{width:96px;flex:0 0 96px}.pagination button{padding:0 14px}.pagination button:disabled{cursor:not-allowed;opacity:.45}table{margin:0 18px 18px;width:calc(100% - 36px);border:1px solid #e7edf4;border-radius:8px;border-collapse:separate;border-spacing:0;overflow:hidden}th{height:42px;background:#f8fafc;font-size:13px;font-weight:700}td,th{color:#001b44}td{height:46px;background:#fff;font-size:14px}td,th{padding:8px 14px;border:0;border-bottom:1px solid #edf1f6}tbody tr:last-child td{border-bottom:0}.category-level-badge{height:24px;padding:0 10px;display:inline-flex;align-items:center;border-radius:12px;font-size:12px;font-weight:800}.category-level-badge.level-1{color:#2f6fd6;background:#eef5ff;border:1px solid #cfe0ff}.category-level-badge.level-2{color:#16794f;background:#ecfdf3;border:1px solid #bbf0d2}.category-level-badge.level-3{color:#b76a00;background:#fff7e8;border:1px solid #ffe1a8}.row-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.row-actions button:disabled{cursor:not-allowed;opacity:.45}.part-thumb{width:40px;height:40px;border-radius:4px}.modal{border-radius:8px;border:1px solid #e7edf4}.modal h4{color:#001b44;font-size:16px;font-weight:800}.modal-form-item label{color:#001b44;font-size:14px;font-weight:700}.notice{border-radius:8px;color:#001b44}