.confirm-dialog{background:#fff;border-radius:12px;padding:24px;min-width:360px;max-width:420px;box-shadow:0 20px 60px #0003;animation:confirm-fade-in .2s ease}.confirm-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 16px}.confirm-icon.warning{background:linear-gradient(135deg,#fff7e6,#ffe7ba);color:#fa8c16}.confirm-icon.danger{background:linear-gradient(135deg,#fff1f0,#ffccc7);color:#f5222d}.confirm-icon.info{background:linear-gradient(135deg,#e6f7ff,#bae7ff);color:#1890ff}.confirm-icon.success{background:linear-gradient(135deg,#f6ffed,#d9f7be);color:#52c41a}.confirm-title{font-size:18px;font-weight:600;color:#1f2937;text-align:center;margin-bottom:8px}.confirm-message{font-size:14px;color:#6b7280;text-align:center;line-height:1.6;margin-bottom:24px}.confirm-actions{display:flex;justify-content:center;gap:12px}.confirm-actions button{min-width:80px;text-align:center}@keyframes confirm-fade-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.auth-page{min-height:100vh;position:fixed;top:0;left:0;width:100%;height:100%;overflow:hidden}.page-bg{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;background:#020617 url(https://images.unsplash.com/photo-1451187580459-43490279c0fa?w=1920) center/cover no-repeat}.page-bg:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#02061733,#02061780,#020617a6);pointer-events:none}.page-bg:after{content:"";position:absolute;inset:0;background-image:radial-gradient(1.5px 1.5px at 50% 50%,rgba(255,255,255,.05),transparent);background-size:80px 80px;pointer-events:none;opacity:.3}.auth-layout{height:100vh;min-height:100vh;max-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 48px;gap:180px;overflow:hidden}.left-panel{flex:1;display:flex;flex-direction:column;justify-content:center;min-width:0;min-height:0;max-width:560px;padding-right:48px}.left-panel-content{display:flex;flex-direction:column;align-items:flex-start}.brand-logo{display:flex;align-items:center;gap:16px;margin-bottom:24px;font-size:28px;cursor:pointer}.brand-logo-icon{height:48px;width:48px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:12px;overflow:hidden}.logo-img{width:40px;height:40px;object-fit:contain}.brand-logo-text{font-size:28px;font-weight:700;color:#fff;letter-spacing:0}.brand-title{font-size:52px;font-weight:900;color:#fff;margin-top:24px;margin-bottom:24px;letter-spacing:.15em;line-height:1.3;font-style:italic;font-family:Source Han Sans CN Heavy,Source Han Sans CN,Noto Sans SC,PingFang SC,Microsoft YaHei,sans-serif}.brand-slogan-row{display:flex;flex-direction:column;align-items:flex-start;width:max-content;margin-top:-10px;margin-bottom:24px}.brand-slogan{display:inline-block;width:max-content;font-size:20px;font-weight:700;color:#fff;margin:0;line-height:1.35;padding:6px 0;background:transparent;letter-spacing:0}.brand-slogan-underline{flex-shrink:0;width:100%;height:5px;background:#2563eb;border-radius:3px;margin-top:6px;margin-bottom:1em;box-shadow:0 0 12px #3b82f699,0 0 24px #3b82f659}.feature-list{list-style:none;margin-bottom:24px;padding-left:0}.feature-list li{display:flex;align-items:center;gap:12px;font-size:16px;font-weight:400;color:#fff;margin-bottom:16px;line-height:1.6;letter-spacing:1px}.feature-list li:last-child{margin-bottom:0}.feature-list li:before{content:"";width:5px;height:5px;background:#38bdf8;transform:rotate(45deg);flex-shrink:0}.version-text{font-size:16px;color:#fff;margin-bottom:16px;margin-top:0;display:flex;align-items:center;gap:12px;line-height:1.6;font-weight:400;letter-spacing:1px}.version-text:before{content:"";display:inline-block;width:5px;height:5px;background:#38bdf8;transform:rotate(45deg);flex-shrink:0}.left-copyright{font-size:13px;line-height:1.5;color:#94a3b8;margin-top:4.5em;flex-shrink:0;text-align:left}.right-panel{display:flex;align-items:center;justify-content:center;flex:0 0 480px;min-width:0;min-height:0;padding-right:0}.auth-card{background:#1d243b;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:28px 36px 24px;width:100%;max-width:480px;box-shadow:0 25px 50px -12px #00000080}.register-card{max-height:90vh;overflow-y:auto}.back-link{margin-bottom:16px}.back-link a{display:inline-flex;align-items:center;gap:6px;color:#6e9cff;font-size:13px;text-decoration:none;transition:color .2s}.back-link a:hover{color:#8babff}.auth-card h2{font-size:18px;font-weight:700;text-align:center;margin-bottom:8px;color:#fff;letter-spacing:.2em}.form-desc{text-align:center;font-size:12px;color:#8890a5;margin-bottom:24px}.auth-card .form-group{margin-bottom:16px}.auth-card .form-label{font-size:13px;color:#d8d8d8;font-weight:500;letter-spacing:.02em;display:block;margin-bottom:8px}.auth-card .form-label .required{color:#f5222d;margin-left:2px}.auth-card .input-wrap{position:relative;display:flex;align-items:center}.auth-card .form-input{width:100%;height:38px;padding:9px 12px;background:#262f4a!important;border:1px solid #4A577B;border-radius:6px;font-size:13px;color:#fff!important;outline:none;transition:all .2s;line-height:1.5;box-sizing:border-box}.auth-card .form-input::placeholder{color:#8890a5!important}.auth-card .form-select{width:100%;height:38px;padding:9px 12px;background:#262f4a!important;border:1px solid #4A577B;border-radius:6px;font-size:13px;color:#fff!important;outline:none;transition:all .2s;line-height:1.5;box-sizing:border-box;cursor:pointer}.auth-card .form-select option{background:#262f4a;color:#fff}.auth-card .radio-card-group{display:flex;gap:12px}.auth-card .radio-card{flex:1;padding:12px;border:1px solid #4A577B;border-radius:6px;cursor:pointer;text-align:center;color:#8890a5;transition:all .2s;background:#262f4a}.auth-card .radio-card:hover{border-color:#60a5fa;color:#fff}.auth-card .radio-card-active{border-color:#3671ff;background:#3671ff26;color:#60a5fa}.auth-card .radio-card input{margin-right:6px}.auth-card .form-input:hover{border-color:#60a5fa}.auth-card .form-input:focus{border-color:#3671ff;box-shadow:0 0 0 3px #3671ff26}.auth-card .form-input.input-error{border-color:#f5222d}.auth-card .password-wrap .form-input{padding-right:42px}.auth-card .password-toggle{position:absolute;right:10px;top:0;bottom:0;height:100%;margin:0;background:none;border:none;cursor:pointer;padding:0 4px;display:flex;align-items:center;justify-content:center;color:#6e9cff;transition:color .2s}.auth-card .password-toggle:hover{color:#8babff}.auth-card .mobile-input-wrap{display:flex;align-items:center;background:#262f4a;border:1px solid #4A577B;border-radius:6px;overflow:hidden;transition:all .2s}.auth-card .mobile-input-wrap:hover{border-color:#60a5fa}.auth-card .mobile-input-wrap:focus-within{border-color:#3671ff;box-shadow:0 0 0 3px #3671ff26}.auth-card .mobile-input-wrap .country-code{padding:0 12px;font-size:13px;color:#8890a5;background:transparent;border-right:1px solid #4A577B;height:38px;display:flex;align-items:center;flex-shrink:0}.auth-card .mobile-input{border:none!important;border-radius:0!important;background:transparent!important;flex:1;color:#fff!important}.auth-card .mobile-input:hover,.auth-card .mobile-input:focus{border:none!important;box-shadow:none!important}.auth-card .captcha-row{display:flex;gap:12px;align-items:center}.auth-card .captcha-input-wrap{flex:1}.auth-card .captcha-box{height:38px;min-width:100px;border-radius:6px;overflow:hidden;cursor:pointer;flex-shrink:0}.auth-card .captcha-box img{width:100%;height:100%;object-fit:cover;display:block}.auth-card .captcha-loading{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:#f0f5ff;color:#666;font-size:12px;border-radius:6px}.auth-card .error-text{color:#f5222d;font-size:12px;margin-top:4px}.auth-card .password-hint{margin-top:8px;padding:8px;background:#0000004d;border-radius:4px}.auth-card .password-strength{font-size:12px;margin-bottom:6px}.auth-card .password-strength.error{color:red}.auth-card .password-strength.warning{color:#ff7e05}.auth-card .password-strength.success{color:#52c41a}.auth-card .password-progress{height:4px;background:#4a577b;border-radius:2px;overflow:hidden}.auth-card .password-progress-bar{height:100%;transition:all .3s}.auth-card .password-tip{font-size:11px;color:#8890a5;margin-top:8px}.auth-card .submit-btn{width:100%;height:40px;background:#3671ff;color:#fff;border:none;border-radius:6px;padding:12px;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:8px;box-shadow:0 4px 6px -1px #0003}.auth-card .submit-btn:hover{transform:translateY(-1px);box-shadow:0 10px 15px -3px #3b82f659}.auth-card .submit-btn:active{transform:translateY(0)}.auth-card .submit-btn:disabled{background:#4a577b!important;cursor:not-allowed;transform:none;box-shadow:none}.auth-card .login-link{text-align:center;font-size:12px;color:#8890a5;margin-top:16px}.auth-card .login-link a{color:#6e9cff;text-decoration:none;transition:color .2s}.auth-card .login-link a:hover{color:#8babff}.auth-card .footer-separator{color:#4a577b;margin:0 8px}.result-card{text-align:center}.result-content{padding:20px 0}.result-icon{margin-bottom:20px;text-align:center}.result-desc{font-size:14px;color:#8890a5;margin-top:12px}@media(max-width:1440px){.auth-layout{padding:32px 48px;gap:180px}.left-panel{max-width:520px;padding-right:36px}.brand-title{font-size:46px}.right-panel{flex:0 0 440px}}@media(max-width:1280px){.auth-layout{padding:28px 40px;gap:140px}.left-panel{max-width:460px;padding-right:28px}.brand-title{font-size:40px;margin-top:20px;margin-bottom:20px}.brand-logo-text{font-size:24px}.brand-slogan{font-size:18px}.feature-list li{font-size:15px;margin-bottom:14px}.right-panel{flex:0 0 400px}.auth-card{padding:24px 28px 20px;max-width:400px}}@media(max-width:1024px){.auth-layout{flex-direction:column;justify-content:center;padding:24px;gap:30px;transform:none}.left-panel{padding-right:0;max-width:none;flex:none;display:flex;justify-content:center}.left-panel-content{align-items:center;margin-left:0;margin-top:0;padding:20px 0}.brand-slogan-row{justify-content:center}.brand-slogan{text-align:center}.feature-list{align-self:center;padding-left:0}.feature-list li,.version-text{justify-content:center}.version-text:before{display:none}.left-copyright{text-align:center;margin-top:2em}.right-panel{flex:none;width:100%;max-width:420px;margin:0 auto;padding:0;align-items:center;justify-content:center}.auth-card{max-width:100%;transform:scale(1);margin-top:0;padding:26px 32px 22px}}@media(max-width:768px){.auth-page{overflow-y:auto}.auth-layout{padding:20px 16px;gap:24px;min-height:auto;height:auto;min-height:100vh}.left-panel{display:none}.right-panel{width:100%;max-width:100%}.auth-card{padding:20px 20px 16px;border-radius:12px}.auth-card h2{font-size:16px;margin-bottom:20px}.auth-card .form-input{padding:8px 10px!important;font-size:13px!important}.auth-card .submit-btn{height:38px;font-size:13px;margin-top:8px}}@media(max-width:480px){.auth-card{padding:16px 16px 14px;border-radius:10px}.auth-card h2{font-size:15px;margin-bottom:16px}.form-input{padding:7px 9px!important;font-size:12px!important}.submit-btn{height:36px;font-size:12px}}@media(min-width:1920px){.auth-layout{padding:60px 90px;gap:260px}.left-panel{max-width:720px;padding-right:70px}.brand-logo-icon{height:56px;width:56px}.brand-logo-text{font-size:32px}.brand-title{font-size:64px;margin-top:32px;margin-bottom:32px}.brand-slogan{font-size:24px}.feature-list li{font-size:18px;margin-bottom:20px}.version-text{font-size:18px}.right-panel{flex:0 0 520px}.auth-card{padding:36px 42px 28px;max-width:520px;border-radius:16px}.auth-card h2{font-size:20px;margin-bottom:28px}.auth-card .form-label{font-size:14px}.auth-card .form-input{padding:12px 14px!important;font-size:14px!important;height:44px!important}.auth-card .submit-btn{height:44px;font-size:14px;margin-top:16px}}.production-page{padding:30px;background:#f9fafc;min-height:100%}.production-tabs{margin-bottom:24px;display:flex;gap:10px;background:#fff;padding:4px;border-radius:8px;width:fit-content;border:1px solid #E5E7EB}.production-tab-btn{padding:8px 15px;border-radius:6px;border:none;background:transparent;color:#666;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s;display:flex;align-items:center;gap:6px}.production-tab-btn:hover{background:#f3f4f6;color:#374151}.production-tab-btn-active,.production-tab-btn-active:hover{background:#2563eb;color:#fff}.production-table-qty{color:#333;font-weight:600}.production-table-qty span{color:#999;font-weight:400}.production-progress-cell{display:flex;align-items:center;gap:8px;justify-content:flex-end}.production-progress-bar{width:60px;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.production-progress-fill{height:100%;background:#22c55e;border-radius:3px;transition:width .3s ease}.production-progress-text{color:#22c55e;min-width:40px;text-align:right;font-weight:500;font-size:13px}.inventory-page{padding:30px;background:#f9fafc;min-height:100%}.inventory-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.inventory-header-left{display:flex;align-items:center;gap:12px}.inventory-title{font-size:18px;font-weight:700;color:#111827}.inventory-tabs{margin-bottom:20px;display:flex;gap:4px;background:#fff;padding:4px;border-radius:8px;width:fit-content;border:1px solid #E5E7EB}.inventory-tab{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;background:transparent;color:#6b7280;display:flex;align-items:center;gap:6px}.inventory-tab:hover{background:#f3f4f6;color:#374151}.inventory-tab-active,.inventory-tab-active:hover{background:#2563eb;color:#fff}.approval-alert{margin-bottom:24px;background:#fff7ed;border:1px solid #FFEDD5;padding:12px 20px;border-radius:8px;display:flex;align-items:center;gap:12px}.approval-alert-title{font-size:14px;color:#9a9012;font-weight:600}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.ai-alert-panel{border-radius:12px;background:linear-gradient(135deg,#fff2ec,#fff8f5);border:1px solid #FFD5C0;padding:16px 20px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;gap:16px}.ai-alert-panel-content{display:flex;align-items:flex-start;gap:10px}.ai-alert-panel-icon{font-size:20px}.ai-alert-panel-title{font-size:13px;font-weight:700;color:#d45a30;margin-bottom:4px}.ai-alert-panel-desc{font-size:12px;color:#666;line-height:1.6}.ai-alert-btn{padding:8px 16px;border-radius:8px;background:#ff9e7d;border:none;color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap}.ai-alert-btn:hover{background:#ff8a5c}.pending-approval-alert{margin-bottom:16px;background:#fef3c7;border-radius:8px;padding:12px 16px}.pending-approval-alert-content{display:flex;align-items:center;gap:8px}.pending-approval-alert-icon{color:#d97706}.pending-approval-alert-text{color:#92400e;font-size:13px}.pending-approvals{margin-bottom:24px}.pending-approvals-title{font-size:16px;font-weight:700;color:#333;margin-bottom:12px;display:flex;align-items:center;gap:8px}.pending-approval-item{background:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:16px}.pending-approval-header{display:flex;justify-content:space-between;margin-bottom:12px}.pending-approval-id{font-size:14px;font-weight:600;color:#111;margin-right:12px}.pending-approval-date,.pending-approval-meta{font-size:13px;color:#666}.diff-table{width:100%;border-collapse:collapse;margin-bottom:12px}.diff-table th{text-align:left;font-size:12px;color:#6b7280;padding:0 8px 8px 0}.diff-table td{padding:8px 8px 8px 0;font-size:13px;color:#374151}.diff-positive{color:#d97706}.diff-negative{color:#dc2626}.inventory-alert{margin-bottom:24px}.inventory-alert-card{background:#fffbeb;border:1px solid #FDE68A;border-radius:8px;padding:16px}.inventory-alert-content{display:flex;align-items:flex-start;gap:10px}.inventory-alert-title{font-size:13px;font-weight:700;color:#d45a30;margin-bottom:4px}.inventory-alert-desc{font-size:12px;color:#666;line-height:1.6}.inventory-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.inventory-filters{display:flex;gap:12px;align-items:center}.inventory-filter-select{padding:5px 10px;border-radius:6px;border:1px solid #E6E8EB;font-size:12px;color:#333;outline:none;cursor:pointer;background-color:#fff;min-width:110px;font-family:inherit}.inventory-filter-select:focus{border-color:#2563eb}.inventory-filter-btn{padding:6px 12px;border-radius:6px;font-size:12px;border:1px solid #E5E7EB;background:#fff;color:#666;cursor:pointer;transition:all .2s}.inventory-filter-btn:hover{border-color:#2563eb;color:#2563eb}.inventory-filter-btn-active{background:#2563eb;border-color:#2563eb;color:#fff}.inventory-search{position:relative}.inventory-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#999}.inventory-search-input{padding:6px 12px 6px 30px;border-radius:7px;border:1px solid #E6F0FF;background:#f9fafc;font-size:14px;color:#333;outline:none;width:200px}.inventory-table{width:100%;border-collapse:collapse}.inventory-table th{text-align:left;padding:11px 16px 11px 0;color:#666;font-size:13px;border-bottom:1px solid #F0F5FF;font-weight:500}.inventory-table th:hover{background:#fff!important}.inventory-table td{padding:11px 16px 11px 0;font-size:12px;border-bottom:1px solid #F9FAFC;transition:background .1s ease;cursor:pointer}.inventory-table tbody tr:hover td{background:#f9fafc}.inventory-table-code{color:#2563eb;font-weight:600;font-family:monospace}.inventory-table-name{color:#333;font-weight:500}.inventory-table-remark{color:#666}.inventory-table-date{color:#999}.inventory-table-actions{padding:11px 0}.inventory-table-category{font-size:11px;color:#666;background:#f4f5f7;padding:2px 8px;border-radius:4px}.inventory-table-qty{color:#333;font-weight:600}.inventory-table-qty-unit{color:#999;font-weight:400}.inventory-table-available{font-weight:600}.inventory-table-available-low{color:#d45a30}.inventory-table-available-normal{color:#10b981}.inventory-table-actions{display:flex;gap:6px}.inventory-table-action-btn{font-size:11px;color:#2563eb;background:none;border:none;cursor:pointer;font-family:inherit;padding:2px 0}.inventory-table-action-btn:hover{text-decoration:underline}.inventory-table-action-btn-danger{color:#ef4444;font-weight:600}.materials-table{width:100%;border-collapse:collapse}.materials-table th{text-align:left;font-size:11px;color:#999;font-weight:500;padding:0 16px 10px 0;border-bottom:1px solid #F0F5FF;white-space:nowrap}.materials-table td{padding:11px 16px 11px 0;font-size:12px;border-bottom:1px solid #F9FAFC;transition:background .1s ease}.materials-table tbody tr:hover td{background:#f9fafc}.materials-table-code{color:#2563eb;font-weight:600;font-family:monospace}.materials-table-name{color:#333;font-weight:500}.materials-table-spec{color:#666}.materials-table-remark{color:#999;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.warehouse-table{width:100%;border-collapse:collapse}.warehouse-table th{text-align:left;font-size:11px;color:#999;font-weight:500;padding:0 16px 10px 0;border-bottom:1px solid #F0F5FF;white-space:nowrap}.warehouse-table td{padding:11px 16px 11px 0;font-size:12px;border-bottom:1px solid #F9FAFC;transition:background .1s ease}.warehouse-table tbody tr:hover td{background:#f9fafc}.warehouse-table-code{color:#2563eb;font-weight:600;font-family:monospace}.warehouse-table-name{color:#333;font-weight:500}.warehouse-table-remark{color:#666}.warehouse-table-date{color:#999}.inventory-modal-overlay{position:fixed;inset:0;background-color:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center}.inventory-modal{background-color:#fff;border-radius:12px;width:800px;max-width:90%;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;overflow:hidden;display:flex;flex-direction:column;max-height:90vh}.inventory-modal-header{padding:20px 24px;border-bottom:1px solid #E5E7EB;display:flex;justify-content:space-between;align-items:center}.inventory-modal-title{font-size:18px;font-weight:600;margin:0;color:#111827}.inventory-modal-close{border:none;background:transparent;cursor:pointer;color:#9ca3af}.inventory-modal-body{padding:24px;overflow-y:auto}.steps-tip{margin-bottom:20px;padding:16px;border-radius:8px;border:1px solid #E5E7EB}.steps-tip-title{font-size:14px;font-weight:600;margin-bottom:12px}.steps-tip-content{display:flex;align-items:center;gap:8px;font-size:12px;color:#6b7280}.steps-tip-inbound{background:#f9fafc}.steps-tip-outbound{background:#fef3c7;border-color:#fcd34d}.steps-tip-outbound .steps-tip-title{color:#92400e}.steps-step{padding:4px 10px;border-radius:12px;font-weight:500}.steps-step-active{background:#dbeafe;color:#1d4ed8}.steps-step-active-outbound{background:#fef3c7;color:#b45309}.steps-step-done{background:#d1fae5;color:#065f46}.steps-step-pending{background:#f3f4f6;color:#6b7280}.steps-arrow{color:#d1d5db}.type-select-group{margin-bottom:20px}.type-select-label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:12px}.doc-no-display{margin-bottom:20px;padding:12px;border-radius:8px;border:1px solid}.doc-no-display-inbound{background:#f0f9ff;border-color:#bae6fd}.doc-no-display-outbound{background:#fef3c7;border-color:#fcd34d}.current-item-info{margin-bottom:20px;padding:12px;background:#f9fafc;border-radius:8px;border:1px solid #E5E7EB}.current-item-label{font-size:12px;color:#6b7280;margin-bottom:4px}.current-item-value{font-size:14px;font-weight:600;color:#111827}.current-item-meta{font-size:12px;color:#6b7280;margin-top:4px}.material-select-section{margin-bottom:20px}.material-select-label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:12px}.material-input-group{display:flex;gap:8px}.material-input{flex:1;padding:10px 12px;border-radius:6px;border:1px solid #E5E7EB;font-size:14px;outline:none;transition:border-color .2s}.material-input:focus{border-color:#2563eb}.material-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #E5E7EB;border-radius:6px;box-shadow:0 4px 12px #0000001a;max-height:200px;overflow-y:auto;z-index:10;margin-top:4px}.material-dropdown-item{padding:10px 12px;cursor:pointer;transition:background .2s}.material-dropdown-item:hover{background:#f3f4f6}.material-dropdown-item-name{font-size:13px;font-weight:500;color:#333}.material-dropdown-item-code{font-size:11px;color:#999;font-family:monospace}.material-items-table{width:100%;border-collapse:collapse;margin-bottom:16px}.material-items-table th{text-align:left;font-size:12px;color:#6b7280;padding:8px;border-bottom:1px solid #E5E7EB;font-weight:500}.material-items-table td{padding:12px 8px;border-bottom:1px solid #F3F4F6}.material-items-table input{width:100%;padding:8px;border:1px solid #E5E7EB;border-radius:6px;font-size:13px;outline:none}.material-items-table input:focus{border-color:#2563eb}.material-items-table-remove{color:#ef4444;cursor:pointer;padding:4px}.form-remark-section{margin-top:16px}.form-remark-label{font-size:13px;color:#6b7280;margin-bottom:6px;display:block}.form-remark-textarea{width:100%;padding:10px;border:1px solid #E5E7EB;border-radius:6px;font-size:13px;resize:vertical;min-height:80px;outline:none}.form-remark-textarea:focus{border-color:#2563eb}.modal-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid #E5E7EB;margin-top:16px}.quick-stocktake-active{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center}.quick-stocktake-panel{background:#fff;border-radius:12px;width:600px;max-width:90%;padding:24px;box-shadow:0 20px 25px -5px #0000001a}.quick-stocktake-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.quick-stocktake-title{font-size:18px;font-weight:600;color:#111827}.quick-stocktake-search{margin-bottom:20px}.quick-stocktake-search-input{width:100%;padding:12px 16px;border:2px solid #2563EB;border-radius:8px;font-size:16px;outline:none}.quick-stocktake-list{max-height:400px;overflow-y:auto}.quick-stocktake-item{display:flex;justify-content:space-between;align-items:center;padding:12px;border-bottom:1px solid #F3F4F6}.quick-stocktake-item-info{flex:1}.quick-stocktake-item-name{font-size:14px;font-weight:500;color:#333}.quick-stocktake-item-code{font-size:12px;color:#999;font-family:monospace}.quick-stocktake-item-qty{display:flex;align-items:center;gap:8px}.quick-stocktake-qty-btn{width:32px;height:32px;border-radius:6px;border:1px solid #E5E7EB;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.quick-stocktake-qty-btn:hover{background:#f3f4f6}.quick-stocktake-qty-input{width:60px;text-align:center;padding:6px;border:1px solid #E5E7EB;border-radius:6px;font-size:14px}.stocktake-task-card{background:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:16px;margin-bottom:12px}.stocktake-task-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.stocktake-task-id{font-size:14px;font-weight:600;color:#111}.stocktake-task-status{padding:4px 8px;border-radius:4px;font-size:12px}.stocktake-task-status-pending{background:#fef3c7;color:#92400e}.stocktake-task-status-completed{background:#d1fae5;color:#065f46}.stocktake-task-status-processing{background:#dbeafe;color:#1d4ed8}.stocktake-task-meta{font-size:12px;color:#666;display:flex;gap:16px}.tab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.tab-title{font-size:15px;font-weight:600;color:#333;margin:0}.tab-count{font-size:12px;color:#999}.diff-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1050}.diff-modal{background:#fff;border-radius:12px;width:700px;max-width:90%;max-height:80vh;display:flex;flex-direction:column}.diff-modal-header{padding:20px 24px;border-bottom:1px solid #E5E7EB;display:flex;justify-content:space-between;align-items:center}.diff-modal-title{font-size:18px;font-weight:600;color:#111827;margin:0}.diff-modal-body{padding:24px;overflow-y:auto}.diff-reason-input{width:100%;padding:8px;border:1px solid #E5E7EB;border-radius:6px;font-size:13px}.inventory-ai-alert-card{border-radius:12px;background:linear-gradient(135deg,#fff2ec,#fff8f5);border:1px solid #FFD5C0;padding:16px 20px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;gap:16px}.inventory-ai-alert-content{display:flex;align-items:flex-start;gap:10px}.inventory-ai-alert-icon{font-size:20px}.inventory-ai-alert-title{font-size:13px;font-weight:700;color:#d45a30;margin-bottom:4px}.inventory-ai-alert-desc{font-size:12px;color:#666;line-height:1.6}.inventory-ai-alert-btn{padding:8px 16px;border-radius:8px;background:#ff9e7d;border:none;color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .2s}.inventory-ai-alert-btn:hover{background:#ff8a5c}.inventory-tab-btn{padding:8px 20px;border-radius:6px;border:none;background:transparent;color:#666;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s;display:flex;align-items:center;gap:6px}.inventory-tab-btn:hover{background:#f3f4f6;color:#374151}.inventory-tab-btn-active,.inventory-tab-btn-active:hover{background:#2563eb;color:#fff}.pending-approval-actions{display:flex;justify-content:flex-end;gap:8px}.warehouse-list-header{display:flex;gap:12px;align-items:center}.warehouse-list-title{font-size:15px;font-weight:600;color:#333;margin:0}.warehouse-list-count{font-size:12px;color:#999}.inventory-table-cell-code{padding:11px 16px 11px 0;font-size:12px;color:#2563eb;font-weight:600;font-family:monospace}.inventory-table-cell-name{padding:11px 16px 11px 0;font-size:12px;color:#333;font-weight:500}.inventory-table-cell-category{padding:11px 16px 11px 0}.inventory-table-cell-category span{font-size:11px;color:#666;background:#f4f5f7;padding:2px 8px;border-radius:4px}.inventory-table-cell-warehouse{padding:11px 16px 11px 0;font-size:12px;color:#333}.inventory-table-cell-qty{padding:11px 16px 11px 0;font-size:12px;color:#333;font-weight:600}.inventory-table-cell-qty span{color:#999;font-weight:400}.inventory-table-cell-available{padding:11px 16px 11px 0;font-size:12px;font-weight:600}.inventory-table-cell-available-safe{color:#10b981}.inventory-table-cell-available-danger{color:#d45a30}.inventory-table-cell-available span{color:#999;font-weight:400}.inventory-table-cell-date{padding:11px 16px 11px 0;font-size:12px;color:#999}.inventory-table-cell-actions{padding:11px 0}.inventory-table-cell-actions-flex{display:flex;gap:6px}.inventory-table-action-btn{font-size:11px;color:#2563eb;background:none;border:none;cursor:pointer;font-family:inherit;padding:2px 0;transition:color .2s}.inventory-table-action-btn:hover{color:#2563eb}.inventory-table-action-btn-danger{color:#ef4444}.inventory-table-action-btn-danger:hover{color:#dc2626}.material-table-cell-code{padding:11px 16px 11px 0;font-size:12px;color:#2563eb;font-weight:600;font-family:monospace}.material-table-cell-name{padding:11px 16px 11px 0;font-size:12px;color:#333;font-weight:500}.material-table-cell-spec,.material-table-cell-unit{padding:11px 16px 11px 0;font-size:12px;color:#666}.material-table-cell-minstock{padding:11px 16px 11px 0;font-size:12px;color:#999}.material-table-cell-remark{padding:11px 16px 11px 0;font-size:12px;color:#999;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.material-table-cell-actions{padding:11px 0}.material-table-actions-flex{display:flex;gap:8px}.material-table-action-btn{font-size:11px;color:#2563eb;background:none;border:none;cursor:pointer;font-family:inherit;padding:2px 0;display:flex;align-items:center;gap:2px;transition:color .2s}.material-table-action-btn:hover{color:#2563eb}.material-table-action-btn-delete{color:#ef4444}.material-table-action-btn-delete:hover{color:#dc2626}.warehouse-table-cell-code{padding:11px 16px 11px 0;font-size:12px;color:#2563eb;font-weight:600;font-family:monospace}.warehouse-table-cell-name{padding:11px 16px 11px 0;font-size:12px;color:#333;font-weight:500}.warehouse-table-cell-remark{padding:11px 16px 11px 0;font-size:12px;color:#666}.warehouse-table-cell-date{padding:11px 16px 11px 0;font-size:12px;color:#999}.warehouse-table-cell-actions{padding:11px 0}.warehouse-table-actions-flex{display:flex;gap:8px}.warehouse-table-action-btn{font-size:11px;color:#2563eb;background:none;border:none;cursor:pointer;font-family:inherit;padding:2px 0;display:flex;align-items:center;gap:4px;transition:color .2s}.warehouse-table-action-btn:hover{text-decoration:underline}.warehouse-table-action-btn-delete{color:#ef4444;font-weight:600}.warehouse-table-action-btn-delete:hover{color:#dc2626}.status-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500}.status-tag-success{background-color:#ecfdf5;color:#10b981}.status-tag-danger{background-color:#fef2f2;color:#ef4444}.text-muted{color:#999}.loading-text{text-align:center;padding:40px;color:#999}.inventory-table-row{border-bottom:1px solid #F9FAFC;transition:background .1s ease}.inventory-table-row:hover{background:#f9fafc}.outbound-btn{margin-left:8px}.modal-overlay{position:fixed;inset:0;background-color:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center}.modal-container{background-color:#fff;border-radius:12px;width:800px;max-width:95%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{padding:20px 24px!important;border-bottom:1px solid #E5E7EB;display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:18px;font-weight:600;margin:0;color:#111827}.modal-close-btn{border:none;background:transparent;cursor:pointer;color:#9ca3af;padding:4px;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{color:#6b7280}.modal-body{padding:24px;overflow-y:auto}.modal-steps{margin-bottom:20px;padding:16px;background:#f9fafc;border-radius:8px;border:1px solid #E5E7EB}.modal-steps-title{font-size:14px;font-weight:600;color:#374151;margin-bottom:12px}.modal-steps-items{display:flex;align-items:center;gap:8px;font-size:12px;color:#6b7280}.modal-step-badge{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.modal-step-badge-active{background:#dbeafe;color:#2563eb}.modal-step-badge-inactive{background:#f3f4f6;color:#9ca3af}.modal-step-arrow{color:#9ca3af}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}.form-input{width:100%;padding:8px 12px;border:1px solid #E5E7EB;border-radius:6px;font-size:13px;color:#374151;outline:none;transition:border-color .2s,box-shadow .2s}.form-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #4a90e21a}.form-select{width:100%;padding:8px 12px;border:1px solid #E5E7EB;border-radius:6px;font-size:13px;color:#374151;outline:none;background:#fff;cursor:pointer}.form-row{display:flex;gap:16px}.form-row>div{flex:1}.operation-tips{margin-bottom:20px;padding:12px 16px;background:#eff6ff;border-radius:8px;border:1px solid #BFDBFE}.operation-tips-text{font-size:13px;color:#1e40af;display:flex;align-items:center;gap:8px}.nested-table{width:100%;border-collapse:collapse;margin-bottom:16px}.nested-table th{text-align:left;font-size:12px;color:#6b7280;padding:0 8px 8px 0;font-weight:500}.nested-table td{padding:8px 8px 8px 0;font-size:13px;color:#374151}.small-table{width:100%;border-collapse:collapse}.small-table th{text-align:left;font-size:13px;color:#6b7280;font-weight:500;padding:8px 0;border-bottom:1px solid #E5E7EB}.small-table th:last-child{text-align:right}.small-table td{padding:8px 0;font-size:13px;color:#374151}.small-table td:last-child{text-align:right}.modal-footer{padding:16px 24px;border-top:1px solid #E5E7EB;display:flex;justify-content:flex-end;gap:12px}.modal-btn{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s}.modal-btn-secondary{padding:8px 16px;border-radius:6px;border:1px solid #D1D5DB;background:#fff;color:#374151;font-size:14px;cursor:pointer;font-weight:500}.modal-btn-secondary:hover{background:#f3f4f6}.modal-btn-primary{padding:8px 16px;border-radius:6px;border:none;background:#2563eb;color:#fff;font-size:14px;cursor:pointer;font-weight:500}.modal-btn-primary:hover{background:#2563eb}.modal-btn-danger{padding:8px 16px;border-radius:6px;border:none;background:#ef4444;color:#fff;font-size:14px;cursor:pointer;font-weight:500}.modal-btn-danger:hover{background:#dc2626}.category-btn-group{display:flex;gap:6px}.category-btn{padding:5px 12px;border-radius:6px;border:none;background:#f9fafc;color:#666;font-size:14px;cursor:pointer;font-family:inherit;transition:all .2s}.category-btn:hover{background:#f3f4f6;color:#374151}.category-btn-active{background:#e6f0ff;color:#2563eb;font-weight:600}.category-btn-active:hover{background:#dbeafe;color:#2563eb}.form-input-lg{width:100%;padding:10px 12px;border-radius:6px;border:1px solid #D1D5DB;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s}.form-input-lg:focus{border-color:#2563eb;box-shadow:0 0 0 3px #4a90e21a}.form-input-lg:disabled{background:#f9fafc;color:#9ca3af;cursor:not-allowed}.form-input-lg-textarea{width:100%;padding:10px 12px;border-radius:6px;border:1px solid #D1D5DB;font-size:14px;outline:none;resize:vertical;min-height:60px;font-family:inherit;transition:border-color .2s,box-shadow .2s}.form-input-lg-textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #4a90e21a}.modal-textarea{width:100%;padding:10px 12px;border-radius:6px;border:1px solid #D1D5DB;font-size:14px;outline:none;resize:vertical;min-height:60px;font-family:inherit;transition:border-color .2s,box-shadow .2s}.modal-textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #4a90e21a}.form-select-lg{width:100%;padding:10px 12px;border-radius:6px;border:1px solid #D1D5DB;font-size:14px;color:#374151;background-color:#fff;outline:none;cursor:pointer;transition:border-color .2s,box-shadow .2s}.form-select-lg:focus{border-color:#2563eb;box-shadow:0 0 0 3px #4a90e21a}.stocktake-type-btn{flex:1;padding:10px;border-radius:6px;border:1px solid;font-size:14px;cursor:pointer;font-weight:500;font-family:inherit;transition:all .2s;background:#fff;color:#374151}.stocktake-type-btn-active{border-color:#2563eb;background:#eff6ff;color:#2563eb}.unit-list{border:1px solid #E5E7EB;border-radius:6px;max-height:200px;overflow-y:auto}.unit-list-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid #F3F4F6}.unit-list-item:last-child{border-bottom:none}.unit-list-item-name{font-size:14px;color:#374151}.unit-list-item-actions{display:flex;gap:8px}.unit-list-item-btn{font-size:12px;color:#6b7280;background:none;border:none;cursor:pointer;padding:2px 4px}.unit-list-item-btn:hover{color:#2563eb}.unit-list-item-btn-delete:hover,.form-required{color:#ef4444}.empty-state{text-align:center;padding:40px 20px;color:#9ca3af}.empty-state-text{font-size:14px}.pending-approval-list{display:flex;flex-direction:column;gap:12px}.inventory-filter-row{display:flex;gap:12px;align-items:center}.inventory-filter-item{display:flex;align-items:center;gap:8px}.inventory-filter-label{font-size:12px;color:#666;white-space:nowrap}.inventory-filter-divider{width:1px;height:20px;background:#e6e8eb}.inventory-filter-group{display:flex;gap:6px}.inbound-modal-steps{margin-bottom:20px;padding:16px;background:#fef3c7;border-radius:8px;border:1px solid #FCD34D}.inbound-modal-steps-title{font-size:14px;font-weight:600;color:#92400e;margin-bottom:12px}.inbound-modal-steps-items{display:flex;align-items:center;gap:8px;font-size:12px;color:#6b7280}.inbound-modal-step-arrow{color:#d1d5db}.type-select-card{flex:1;padding:14px 12px;border-radius:8px;border:2px solid #E5E7EB;background:#fff;cursor:pointer;transition:all .2s ease;text-align:center;display:block}.type-select-card:hover{border-color:#2563eb}.type-select-card.active{border-color:#2563eb!important;background:#eff6ff!important}.type-select-card.active .type-select-card-name{color:#2563eb!important}.type-select-card.outbound-active{border-color:#f59e0b!important;background:#fffbeb!important}.type-select-card.outbound-active .type-select-card-name{color:#f59e0b!important}.type-select-card-name{font-size:14px;font-weight:600;color:#374151;margin-bottom:4px}.type-select-card-desc{font-size:11px;color:#6b7280}.modal-form-section{margin-bottom:20px}.modal-form-section-label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:12px}.modal-form-row{display:flex;gap:12px}.modal-form-row>div{flex:1}.doc-no-card{margin-bottom:20px;padding:12px;background:#f0f9ff;border-radius:8px;border:1px solid #BAE6FD}.doc-no-card-label{font-size:12px;color:#0369a1;margin-bottom:4px}.doc-no-card-value{font-size:16px;font-weight:600;color:#0c4a6e;font-family:monospace}.doc-no-card-warning{background:#fef3c7;border-color:#fcd34d}.doc-no-card-warning .doc-no-card-label{color:#92400e}.doc-no-card-warning .doc-no-card-value{color:#78350f}.doc-no-card-default{background:#f9fafc;border-color:#e5e7eb}.doc-no-card-default .doc-no-card-label{color:#6b7280}.doc-no-card-default .doc-no-card-value{color:#111827}.current-item-card{margin-bottom:20px;padding:12px;background:#f9fafc;border-radius:8px;border:1px solid #E5E7EB}.current-item-card-label{font-size:12px;color:#6b7280;margin-bottom:4px}.current-item-card-name{font-size:14px;font-weight:600;color:#111827}.current-item-card-qty{font-size:12px;color:#6b7280;margin-top:4px}.current-item-card-qty strong{font-weight:600;color:#374151}.modal-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.modal-table-title{font-size:14px;font-weight:500;color:#374151}.modal-table{width:100%;border-collapse:collapse;margin-bottom:16px;table-layout:fixed}.modal-table-wrapper{overflow-x:auto;margin-bottom:16px;border-radius:6px}.modal-table-wrapper::-webkit-scrollbar{height:6px}.modal-table-wrapper::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.modal-table-wrapper::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.modal-table-wrapper::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.inventory-material-dropdown-portal{min-height:40px}.inventory-material-dropdown-portal::-webkit-scrollbar{width:6px}.inventory-material-dropdown-portal::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.inventory-material-dropdown-portal::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.inventory-material-dropdown-portal::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.modal-table th{text-align:left;font-size:12px;color:#6b7280;padding:0 8px 8px 0;font-weight:500}.modal-table td{padding:0 8px 8px 0;position:relative}.modal-table-input{width:100%;padding:8px;border-radius:6px;border:1px solid #D1D5DB;font-size:13px;box-sizing:border-box;overflow:hidden;text-overflow:ellipsis}.modal-table-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #4a90e21a}.modal-table-select{width:100%;padding:8px;border-radius:6px;border:1px solid #D1D5DB;font-size:13px;background-color:#fff}.modal-table-select-readonly{background-color:#f9fafc;color:#6b7280}.modal-table-cell-diff{font-weight:600;padding:6px 8px;border-radius:4px}.modal-table-cell-diff-zero{color:#10b981;background-color:transparent}.modal-table-cell-diff-positive{color:#f59e0b;background-color:#fffbeb}.modal-table-cell-diff-negative{color:#ef4444;background-color:#fef2f2}.batch-info{display:flex;align-items:center;gap:4px}.batch-info-recommended{font-size:10px;color:#0369a1;margin-top:4px}.delete-row-btn{color:#ef4444;border:none;background:transparent;cursor:pointer;padding:4px}.modal-form-label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:8px}.modal-footer{padding:16px 24px;border-top:1px solid #E5E7EB;background:#f9fafc;display:flex;justify-content:flex-end;gap:12px}.inventory-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid #E5E7EB}.pagination-info{font-size:13px;color:#6b7280}.pagination-buttons{display:flex;gap:8px}.pagination-btn{padding:6px 12px;border:1px solid #D1D5DB;border-radius:4px;background:#fff;color:#374151;font-size:13px;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.sales-page{padding:30px;background:#f9fafc;min-height:100%}.sales-tabs{margin-bottom:24px;display:flex;gap:10px;background:#fff;padding:4px;border-radius:8px;width:fit-content;border:1px solid #E5E7EB}.sales-tab-btn{padding:8px 15px;border-radius:6px;border:none;background:transparent;color:#666;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s;display:flex;align-items:center;gap:6px}.sales-tab-btn:hover{background:#f3f4f6;color:#374151}.sales-tab-btn-active,.sales-tab-btn-active:hover{background:#2563eb;color:#fff}.sales-sub-tabs{display:flex;gap:8px;background:#fff;padding:4px;border-radius:8px;border:1px solid #E5E7EB}.sales-sub-tab-btn{padding:8px 15px;border-radius:6px;border:none;background:transparent;color:#666;font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s;display:flex;align-items:center;gap:6px}.sales-sub-tab-btn:hover{background:#f3f4f6;color:#374151}.sales-sub-tab-btn-active,.sales-sub-tab-btn-active:hover{background:#2563eb;color:#fff}.procurement-page{padding:30px;background:#f9fafc;min-height:100%}.procurement-tabs{margin-bottom:24px;display:flex;gap:10px;background:#fff;padding:4px;border-radius:8px;width:fit-content;border:1px solid #E5E7EB}.procurement-tab-btn{padding:8px 15px;border-radius:6px;border:none;background:transparent;color:#666;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s;display:flex;align-items:center;gap:6px}.procurement-tab-btn:hover{background:#f3f4f6;color:#374151}.procurement-tab-btn-active,.procurement-tab-btn-active:hover{background:#2563eb;color:#fff}.finance-page{padding:30px;background:var(--bg-page);min-height:100%}.finance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.finance-header-left{display:flex;align-items:center;gap:12px}.finance-title{font-size:20px;font-weight:700;color:#111827}.finance-tabs{margin-bottom:24px;display:flex;gap:8px;background:#fff;padding:4px;border-radius:10px;width:fit-content;border:1px solid #E5E7EB;box-shadow:var(--shadow-default)}.finance-tab{padding:8px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;color:#6b7280;background:transparent;border:none;display:flex;align-items:center;gap:6px}.finance-tab:hover{color:#2563eb;background:#f0f5ff}.finance-tab.active{color:#fff;background:#2563eb;box-shadow:0 2px 8px #4a90e24d}.finance-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.finance-kpi-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000a;border:1px solid #F0F0F0;position:relative;overflow:hidden;transition:all .2s ease}.finance-kpi-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.finance-kpi-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.finance-kpi-label{font-size:14px;color:#6b7280;font-weight:500}.finance-kpi-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center}.finance-kpi-icon.blue{background:#ebf5ff;color:#2563eb}.finance-kpi-icon.green{background:#e8f5e9;color:#4caf50}.finance-kpi-icon.orange{background:#fff3e0;color:#ff9800}.finance-kpi-icon.red{background:#ffebee;color:#f44336}.finance-kpi-icon.yellow{background:#fffde7;color:#ffc107}.finance-kpi-icon.purple{background:#f3e5f5;color:#9c27b0}.finance-kpi-value{font-size:24px;font-weight:700;color:#111827;margin-bottom:4px}.finance-kpi-sub{font-size:12px;color:#9ca3af;margin-left:8px}.finance-kpi-trend{display:flex;align-items:center;font-size:12px;font-weight:500}.finance-kpi-trend.up{color:#22c55e}.finance-kpi-trend.down{color:#ef4444}.finance-kpi-progress{position:absolute;bottom:0;left:0;height:4px;border-radius:0 2px 2px 0;transition:width .6s ease}.finance-kpi-progress.blue{background:linear-gradient(to right,#2563eb,#73a9ff)}.finance-kpi-progress.green{background:linear-gradient(to right,#4caf50,#81c784)}.finance-kpi-progress.orange{background:linear-gradient(to right,#ff9800,#ffb74d)}.finance-kpi-progress.red{background:linear-gradient(to right,#f44336,#ef5350)}.finance-ai-warning{background:linear-gradient(135deg,#fff7ed,#fffbeb);border:1px solid #FED7AA;border-radius:12px;padding:16px 20px;margin-bottom:24px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #fb923c1a}.finance-warning-content{display:flex;align-items:flex-start;gap:12px}.finance-warning-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fb923c,#ef4444);color:#fff;flex-shrink:0;box-shadow:0 2px 8px #fb923c4d}.finance-warning-title{font-size:14px;font-weight:700;color:#1f2937;margin-bottom:4px}.finance-warning-desc{font-size:12px;color:#6b7280;line-height:1.6}.finance-warning-actions{display:flex;gap:8px;flex-shrink:0}.finance-table-container{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000a;border:1px solid #F0F0F0}.finance-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.finance-table-title{font-size:16px;font-weight:700;color:#1f2937}.finance-table{width:100%;border-collapse:collapse;text-align:left}.finance-table thead tr{border-bottom:1px solid #F3F4F6}.finance-table th{padding:12px 16px;font-size:12px;font-weight:500;color:#6b7280}.finance-table tbody tr{border-bottom:1px solid #F9FAFC;transition:background .15s ease}.finance-table tbody tr:hover{background:#f9fafc}.finance-table td{padding:14px 16px;font-size:14px;color:#374151}.finance-filter-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:16px}.finance-filter-left,.finance-filter-right{display:flex;align-items:center;gap:12px}.finance-status-tag{display:inline-flex;align-items:center;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500}.finance-status-tag.success{background:#dcfce7;color:#16a34a}.finance-status-tag.warning{background:#fef3c7;color:#d97706}.finance-status-tag.danger{background:#fee2e2;color:#dc2626}.finance-status-tag.info{background:#dbeafe;color:#2563eb}.finance-type-tag{display:inline-flex;align-items:center;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500}.finance-type-tag.income{background:#dcfce7;color:#16a34a}.finance-type-tag.expense{background:#ffedd5;color:#ea580c}.finance-modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50}.finance-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000026;overflow:hidden}.finance-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #F3F4F6;background:#f9fafc}.finance-modal-title{font-size:16px;font-weight:700;color:#1f2937;display:flex;align-items:center;gap:8px}.finance-modal-close{color:#9ca3af;transition:color .2s;background:none;border:none;padding:4px;border-radius:4px}.finance-modal-close:hover{color:#6b7280;background:#f3f4f6}.finance-modal-body{padding:24px}.finance-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #F3F4F6;background:#f9fafc}.finance-form-group{margin-bottom:16px}.finance-form-label{display:block;font-size:14px;color:#374151;font-weight:500;margin-bottom:6px}.finance-form-input{width:100%;padding:10px 12px;border:1px solid #E5E7EB;border-radius:8px;font-size:14px;color:#374151;transition:border-color .2s,box-shadow .2s}.finance-form-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #4a90e21a;outline:none}.finance-form-select{width:100%;padding:10px 12px;border:1px solid #E5E7EB;border-radius:8px;font-size:14px;color:#374151;background:#fff;cursor:pointer;transition:border-color .2s,box-shadow .2s}.finance-form-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #4a90e21a;outline:none}.finance-toast{position:fixed;top:24px;left:50%;transform:translate(-50%);background:#1f2937;color:#fff;padding:12px 24px;border-radius:9999px;box-shadow:0 8px 24px #0003;display:flex;align-items:center;gap:8px;z-index:100;animation:toastSlideIn .3s ease}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.flex-1{flex:1}.shrink-0{flex-shrink:0}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.gap-8{gap:32px}.gap-12{gap:48px}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.m-0{margin:0}.m-2{margin:8px}.m-4{margin:16px}.mb-0{margin-bottom:0}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mt-0{margin-top:0}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-5{margin-top:20px}.mt-6{margin-top:24px}.ml-1{margin-left:4px}.ml-2{margin-left:8px}.ml-4{margin-left:16px}.ml-auto{margin-left:auto}.mr-1{margin-right:4px}.mr-2{margin-right:8px}.mx-auto{margin-left:auto;margin-right:auto}.p-0{padding:0}.p-2{padding:8px}.p-3{padding:12px}.p-4{padding:16px}.p-5{padding:20px}.p-6{padding:24px}.px-2{padding-left:8px;padding-right:8px}.px-4{padding-left:16px;padding-right:16px}.px-6{padding-left:24px;padding-right:24px}.py-1{padding-top:4px;padding-bottom:4px}.py-2{padding-top:8px;padding-bottom:8px}.py-3{padding-top:12px;padding-bottom:12px}.py-4{padding-top:16px;padding-bottom:16px}.pb-2{padding-bottom:8px}.pb-3{padding-bottom:12px}.pb-4{padding-bottom:16px}.pt-2{padding-top:8px}.pt-4{padding-top:16px}.pl-3{padding-left:12px}.pl-4{padding-left:16px}.pr-2{padding-right:8px}.pr-3{padding-right:12px}.pr-4{padding-right:16px}.w-full{width:100%}.w-auto{width:auto}.w-1{width:4px}.w-2{width:8px}.w-4{width:16px}.w-8{width:32px}.w-10{width:40px}.w-12{width:48px}.w-40{width:160px}.w-48{width:192px}.w-64{width:256px}.max-w-xs{max-width:320px}.max-w-sm{max-width:384px}.max-w-md{max-width:448px}.max-w-lg{max-width:512px}.max-w-xl{max-width:576px}.max-w-2xl{max-width:672px}.max-w-3xl{max-width:768px}.max-w-4xl{max-width:896px}.min-w-0{min-width:0}.min-h-screen{min-height:100vh}.h-1{height:4px}.h-2{height:8px}.h-4{height:16px}.h-8{height:32px}.h-10{height:40px}.h-12{height:48px}.h-48{height:192px}.h-full{height:100%}.text-xs{font-size:12px}.text-sm{font-size:14px}.text-base{font-size:16px}.text-lg{font-size:18px}.text-xl{font-size:20px}.text-2xl{font-size:24px}.text-3xl{font-size:30px}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.leading-none{line-height:1}.leading-tight{line-height:1.25}.leading-normal{line-height:1.5}.leading-relaxed{line-height:1.625}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.text-white{color:#fff}.text-black{color:#000}.text-gray-100{color:#f3f4f6}.text-gray-200{color:#e5e7eb}.text-gray-300{color:#d1d5db}.text-gray-400{color:#9ca3af}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.text-gray-700{color:#374151}.text-gray-800{color:#1f2937}.text-gray-900{color:#111827}.text-red-50{color:#fef2f2}.text-red-100{color:#fee2e2}.text-red-200{color:#fecaca}.text-red-300{color:#fca5a5}.text-red-400{color:#f87171}.text-red-500{color:#ef4444}.text-red-600{color:#dc2626}.text-orange-50{color:#fff7ed}.text-orange-100{color:#ffedd5}.text-orange-200{color:#fed7aa}.text-orange-300{color:#fdba74}.text-orange-400{color:#fb923c}.text-orange-500{color:#f97316}.text-orange-600{color:#ea580c}.text-yellow-50{color:#fffbeb}.text-yellow-100{color:#fef3c7}.text-yellow-200{color:#fde68a}.text-yellow-400{color:#fbbf24}.text-yellow-500{color:#f59e0b}.text-yellow-600{color:#d97706}.text-green-50{color:#f0fdf4}.text-green-100{color:#dcfce7}.text-green-200{color:#bbf7d0}.text-green-300{color:#86efac}.text-green-400{color:#4ade80}.text-green-500{color:#22c55e}.text-green-600{color:#16a34a}.text-blue-50{color:#eff6ff}.text-blue-100{color:#dbeafe}.text-blue-200{color:#bfdbfe}.text-blue-300{color:#93c5fd}.text-blue-400{color:#60a5fa}.text-blue-500,.text-blue-600{color:#2563eb}.text-blue-700{color:#1d4ed8}.text-blue-800{color:#1e40af}.text-purple-50{color:#faf5ff}.text-purple-100{color:#f3e8ff}.text-purple-200{color:#e9d5ff}.text-purple-300{color:#d8b4fe}.text-purple-400{color:#c084fc}.text-purple-500{color:#a855f7}.text-purple-600{color:#9333ea}.bg-white{background-color:#fff}.bg-black{background-color:#000}.bg-gray-50{background-color:#f9fafb}.bg-gray-100{background-color:#f3f4f6}.bg-gray-200{background-color:#e5e7eb}.bg-gray-300{background-color:#d1d5db}.bg-gray-400{background-color:#9ca3af}.bg-gray-500{background-color:#6b7280}.bg-red-50{background-color:#fef2f2}.bg-red-100{background-color:#fee2e2}.bg-red-400{background-color:#f87171}.bg-red-500{background-color:#ef4444}.bg-orange-50{background-color:#fff7ed}.bg-orange-100{background-color:#ffedd5}.bg-orange-400{background-color:#fb923c}.bg-orange-500{background-color:#f97316}.bg-yellow-50{background-color:#fffbeb}.bg-yellow-100{background-color:#fef3c7}.bg-yellow-400{background-color:#fbbf24}.bg-yellow-500{background-color:#f59e0b}.bg-green-50{background-color:#f0fdf4}.bg-green-100{background-color:#dcfce7}.bg-green-400{background-color:#4ade80}.bg-green-500{background-color:#22c55e}.bg-blue-50{background-color:#eff6ff}.bg-blue-100{background-color:#dbeafe}.bg-blue-400{background-color:#60a5fa}.bg-blue-500{background-color:#2563eb}.bg-purple-50{background-color:#faf5ff}.bg-purple-100{background-color:#f3e8ff}.bg-purple-500{background-color:#a855f7}.bg-black\/10{background-color:#0000001a}.bg-black\/20{background-color:#0003}.bg-white\/20{background-color:#fff3}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.border{border-width:1px;border-style:solid}.border-0{border-width:0}.border-2{border-width:2px}.border-4{border-width:4px}.border-t{border-top-width:1px;border-top-style:solid}.border-b{border-bottom-width:1px;border-bottom-style:solid}.border-l{border-left-width:1px;border-left-style:solid}.border-r{border-right-width:1px;border-right-style:solid}.border-none{border:none}.border-gray-50{border-color:#f9fafb}.border-gray-100{border-color:#f3f4f6}.border-gray-200{border-color:#e5e7eb}.border-gray-300{border-color:#d1d5db}.border-gray-400{border-color:#9ca3af}.border-white{border-color:#fff}.border-blue-500{border-color:#2563eb}.border-orange-200{border-color:#fed7aa}.rounded{border-radius:4px}.rounded-md{border-radius:6px}.rounded-lg{border-radius:8px}.rounded-xl{border-radius:12px}.rounded-2xl{border-radius:16px}.rounded-full{border-radius:9999px}.rounded-t-md{border-top-left-radius:6px;border-top-right-radius:6px}.rounded-b-md{border-bottom-left-radius:6px;border-bottom-right-radius:6px}.rounded-tl-md{border-top-left-radius:6px}.rounded-tr-md{border-top-right-radius:6px}.rounded-bl-md{border-bottom-left-radius:6px}.rounded-br-md{border-bottom-right-radius:6px}.shadow-sm{box-shadow:0 1px 2px #0000000d}.shadow{box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.shadow-xl{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.shadow-none{box-shadow:none}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{inset:0}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.top-full{top:100%}.right-full{right:100%}.bottom-full{bottom:100%}.left-full{left:100%}.float-left{float:left}.float-right{float:right}.clearfix:after{content:"";display:table;clear:both}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-scroll{overflow:scroll}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.transform{transform:translate(var(--tw-translate-x, 0)) translateY(var(--tw-translate-y, 0)) rotate(var(--tw-rotate, 0)) skew(var(--tw-skew-x, 0)) skewY(var(--tw-skew-y, 0)) scaleX(var(--tw-scale-x, 1)) scaleY(var(--tw-scale-y, 1))}.-translate-x-1\/2{transform:translate(-50%)}.-translate-y-1\/2{transform:translateY(-50%)}.rotate-0{transform:rotate(0)}.rotate-45{transform:rotate(45deg)}.rotate-90{transform:rotate(90deg)}.rotate-180{transform:rotate(180deg)}.scale-100{transform:scale(1)}.scale-105{transform:scale(1.05)}.scale-110{transform:scale(1.1)}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.cursor-grab{cursor:grab}.cursor-grabbing{cursor:grabbing}.cursor-text{cursor:text}.cursor-move{cursor:move}.select-none{-webkit-user-select:none;user-select:none}.select-text{-webkit-user-select:text;user-select:text}.select-all{-webkit-user-select:all;user-select:all}.select-auto{-webkit-user-select:auto;user-select:auto}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:background-color,border-color,color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-100{transition-duration:.1s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.duration-700{transition-duration:.7s}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.line-clamp-1{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.resize-none{resize:none}.resize{resize:both}.resize-y{resize:vertical}.resize-x{resize:horizontal}@keyframes toastSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(min-width:640px){.sm\:text-sm{font-size:14px}.sm\:block{display:block}.sm\:flex{display:flex}.sm\:hidden{display:none}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:768px){.md\:text-base{font-size:16px}.md\:block{display:block}.md\:flex{display:flex}.md\:hidden{display:none}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1024px){.lg\:text-lg{font-size:18px}.lg\:block{display:block}.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.hover\:text-white:hover{color:#fff}.hover\:text-gray-600:hover{color:#4b5563}.hover\:text-gray-700:hover{color:#374151}.hover\:text-blue-600:hover{color:#2563eb}.hover\:text-blue-700:hover{color:#1d4ed8}.hover\:text-orange-700:hover{color:#c2410c}.hover\:bg-gray-50:hover{background-color:#f9fafb}.hover\:bg-gray-100:hover{background-color:#f3f4f6}.hover\:bg-orange-50:hover{background-color:#fff7ed}.hover\:bg-blue-50:hover{background-color:#eff6ff}.hover\:bg-blue-50\/30:hover{background-color:#dbeafe4d}.hover\:border-blue-500:hover{border-color:#2563eb}.hover\:shadow-md:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.hover\:underline:hover{text-decoration:underline}.focus\:outline-none:focus{outline:none}.focus\:border-blue-500:focus{border-color:#2563eb}.focus\:ring-1:focus{box-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-blue-500:focus{--tw-ring-color: #2563EB}.focus\:ring-blue-500\/20:focus{--tw-ring-color: rgba(59, 130, 246, .2)}.focus-within\:block:focus-within{display:block}.focus-within\:flex:focus-within{display:flex}.active\:bg-gray-100:active{background-color:#f3f4f6}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.group:hover .group-hover\:block{display:block}.group:hover .group-hover\:flex{display:flex}.group:hover .group-hover\:bg-blue-500{background-color:#2563eb}.group:hover .group-hover\:bg-red-500{background-color:#ef4444}@media(hover:hover){.hover\:rounded-lg:hover{border-radius:8px}}input[type=checkbox],input[type=radio]{width:16px;height:16px;cursor:pointer;accent-color:#2563EB}input[type=checkbox]:focus,input[type=radio]:focus{outline:2px solid #2563EB;outline-offset:2px}select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236B7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 8px center;background-repeat:no-repeat;background-size:20px;padding-right:36px}.finance-dropdown{position:absolute;top:100%;left:0;margin-top:4px;min-width:160px;background:#fff;border:1px solid #E5E7EB;border-radius:8px;box-shadow:0 10px 40px #0000001a;z-index:20;overflow:hidden}.finance-dropdown-item{display:block;width:100%;padding:10px 16px;font-size:14px;color:#374151;text-align:left;background:none;border:none;cursor:pointer;transition:background .15s}.finance-dropdown-item:hover{background:#f3f4f6}.finance-dropdown-item.active{color:#2563eb;font-weight:500;background:#ebf5ff}.finance-filter-panel{position:absolute;top:100%;right:0;margin-top:8px;width:360px;background:#fff;border:1px solid #E5E7EB;border-radius:12px;box-shadow:0 20px 50px #0000001f;z-index:30;overflow:hidden}.finance-filter-panel-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #F3F4F6}.finance-filter-panel-title{font-size:14px;font-weight:700;color:#1f2937}.finance-filter-panel-body{padding:20px}.finance-filter-panel-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid #F3F4F6}.finance-forecast-chart{height:200px;display:flex;align-items:flex-end;justify-content:space-between;gap:8px;border-bottom:2px solid #E5E7EB;padding-bottom:8px}.finance-forecast-bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px}.finance-forecast-bar-fill{width:100%;max-width:48px;border-radius:4px 4px 0 0;transition:all .3s ease}.finance-forecast-bar-fill.positive{background:linear-gradient(to top,#2563eb,#73a9ff)}.finance-forecast-bar-fill.negative{background:linear-gradient(to top,#f87171,#fca5a5)}.finance-forecast-bar-label{font-size:12px;color:#6b7280}.finance-timeline{position:relative;padding-left:24px}.finance-timeline:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,#E5E7EB,transparent)}.finance-timeline-item{position:relative;margin-bottom:16px}.finance-timeline-dot{position:absolute;left:-20px;top:8px;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;border:2px solid #fff;box-shadow:0 2px 4px #0000001a}.finance-timeline-dot.green{background:#dcfce7;color:#16a34a}.finance-timeline-dot.blue{background:#dbeafe;color:#2563eb}.finance-timeline-dot.orange{background:#ffedd5;color:#ea580c}.finance-timeline-content{background:#fff;border:1px solid #E5E7EB;border-radius:10px;padding:14px 16px;box-shadow:0 2px 6px #0000000a}.finance-timeline-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.finance-timeline-title h5{font-size:14px;font-weight:700;color:#1f2937}.finance-timeline-date{font-size:12px;font-weight:500}.finance-timeline-date.green{color:#16a34a}.finance-timeline-date.blue{color:#2563eb}.finance-timeline-date.orange{color:#ea580c}.finance-timeline-desc{font-size:13px;color:#6b7280;line-height:1.6}.finance-gradient-card{background:linear-gradient(135deg,#2563eb,#5ba3f5);border-radius:12px;padding:24px;color:#fff;box-shadow:0 8px 24px #4a90e24d}.finance-gradient-card .label{font-size:14px;color:#fffc;margin-bottom:4px}.finance-gradient-card .value{font-size:32px;font-weight:700;margin-bottom:12px}.finance-gradient-card .stats{display:flex;gap:16px;background:#00000026;border-radius:8px;padding:12px}.finance-gradient-card .stat-item{display:flex;align-items:center;gap:6px;font-size:14px}.finance-gradient-card .stat-item span{color:#ffffffe6}.finance-gradient-card .stat-item strong{font-weight:600}.finance-search{position:relative;width:260px}.finance-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none}.finance-search-input{width:100%;padding:8px 12px 8px 36px;border:1px solid #E5E7EB;border-radius:8px;font-size:14px;color:#374151;background:#fff;transition:border-color .2s,box-shadow .2s}.finance-search-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #4a90e21a;outline:none}.finance-search-input::placeholder{color:#9ca3af}.finance-btn-group{display:flex;gap:8px;padding:4px;background:#f3f4f6;border-radius:8px}.finance-btn-group-item{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;color:#6b7280;background:transparent;border:none}.finance-btn-group-item:hover{color:#374151}.finance-btn-group-item.active{background:#fff;color:#2563eb;box-shadow:0 2px 4px #0000000d}@media(max-width:1280px){.finance-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.finance-kpi-grid{grid-template-columns:1fr}.finance-tabs{flex-wrap:wrap}.finance-filter-bar{flex-direction:column;align-items:stretch}.finance-filter-left,.finance-filter-right{flex-wrap:wrap}.finance-ai-warning{flex-direction:column;gap:16px}}.personnel-page{min-height:100vh;background:#f8fafc;padding-bottom:40px}.personnel-container{max-width:1440px;margin:0 auto;padding:24px}.personnel-header{display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;margin-bottom:32px;gap:16px}@media(min-width:768px){.personnel-header{flex-direction:row;align-items:center}}.personnel-header-left{display:flex;align-items:center;gap:16px}.personnel-header-icon{width:48px;height:48px;background:#2563eb;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 15px -3px #3b82f64d}.personnel-header-icon svg{color:#fff;width:24px;height:24px}.personnel-header-title{font-size:20px;font-weight:700;color:#1e293b}.personnel-header-subtitle{color:#64748b;margin-top:2px}.personnel-header-actions{display:flex;align-items:center;gap:12px}.personnel-tabs{display:flex;background:#fff;border-radius:12px;padding:4px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;width:fit-content}.personnel-tab{padding:10px 24px;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;background:transparent;color:#64748b;display:flex;align-items:center;gap:6px}.personnel-tab:hover{color:#1e293b;background:#f8fafc}.personnel-tab-active{background:#2563eb;color:#fff;box-shadow:0 4px 6px -1px #3b82f64d}.personnel-tab-active:hover{background:#2563eb;color:#fff}.personnel-kpi-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:16px;margin-bottom:24px}@media(min-width:768px){.personnel-kpi-grid{grid-template-columns:repeat(4,1fr)}}.personnel-kpi-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 1px 3px #0000001a;border:1px solid #f1f5f9;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;height:144px}.personnel-kpi-card-top{display:flex;justify-content:space-between;align-items:flex-start}.personnel-kpi-card-title{font-weight:500;color:#64748b;margin-bottom:4px}.personnel-kpi-card-value{font-size:24px;font-weight:700;color:#1e293b;display:flex;align-items:baseline;gap:4px}.personnel-kpi-card-unit{color:#64748b}.personnel-kpi-card-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center}.personnel-kpi-card-icon svg{width:20px;height:20px}.personnel-kpi-card-trend{margin-top:16px;display:flex;align-items:center;gap:8px}.personnel-kpi-card-trend-value{font-size:12px;font-weight:500}.personnel-kpi-card-trend-label{font-size:12px;color:#94a3b8}.personnel-kpi-card-warning{margin-top:16px}.personnel-kpi-card-warning-text{font-size:12px;color:#f59e0b;font-weight:500}.personnel-kpi-card-bar{position:absolute;bottom:0;left:20px;right:20px;height:4px;background:#f1f5f9;border-radius:2px 2px 0 0;overflow:hidden}.personnel-kpi-card-bar-fill{height:100%;border-radius:2px 2px 0 0}.personnel-table-container{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;border:1px solid #f1f5f9;overflow:hidden}.personnel-table-toolbar{padding:16px;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.personnel-filter-group{display:flex;gap:4px;background:#f8fafc;padding:4px;border-radius:10px}.personnel-filter-btn{padding:6px 16px;border-radius:8px;cursor:pointer;transition:all .2s;border:none;background:transparent;color:#64748b}.personnel-filter-btn:hover{background:#e2e8f0}.personnel-filter-btn-active{background:#fff;color:#2563eb;font-weight:500;border:1px solid #e2e8f0;box-shadow:0 1px 2px #0000000d}.personnel-search{position:relative}.personnel-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#94a3b8}.personnel-search-input{padding:6px 12px 6px 36px;border-radius:10px;border:none;background:#f8fafc;outline:none;width:256px}.personnel-table{width:100%;text-align:left;border-collapse:collapse}.personnel-table thead tr{border-bottom:1px solid #f1f5f9;color:#94a3b8}.personnel-table thead th{font-weight:400;padding:16px 24px}.personnel-table tbody tr{border-bottom:1px solid #fafafa;transition:background .1s ease}.personnel-table tbody tr:hover{background:#f8fafc50}.personnel-table tbody td{padding:16px 24px}.personnel-table-code{color:#2563eb;font-weight:500}.personnel-table-name{font-weight:500;color:#1e293b}.personnel-table-dept{font-size:12px;color:#64748b;background:#f1f5f9;padding:4px 8px;border-radius:6px;display:inline-block}.personnel-table-role{color:#64748b}.personnel-table-actions{text-align:right;display:flex;justify-content:flex-end;gap:12px;color:#2563eb}.personnel-table-action-link{cursor:pointer;transition:color .2s}.personnel-table-action-link:hover{color:#2563eb}.personnel-status-tag{padding:4px 8px;border-radius:6px;font-size:12px}.personnel-status-active{background:#ecfdf5;color:#059669}.personnel-status-inactive{background:#f1f5f9;color:#64748b}.personnel-modal-overlay{position:fixed;inset:0;background:#0f172a66;z-index:50;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.personnel-modal{background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;width:100%;max-width:480px;overflow:hidden;transform:transition-all}.personnel-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #f1f5f9}.personnel-modal-title{font-weight:700;color:#1e293b}.personnel-modal-close{border:none;background:transparent;cursor:pointer;color:#94a3b8;padding:4px;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center}.personnel-modal-close:hover{color:#475569;background:#f1f5f9}.personnel-modal-body{padding:24px}.personnel-modal-footer{padding:16px;border-top:1px solid #f1f5f9;background:#f8fafc50;display:flex;justify-content:flex-end;gap:12px;border-radius:0 0 16px 16px}.personnel-profile-avatar{width:80px;height:80px;background:linear-gradient(135deg,#dbeafe,#eef2ff);color:#2563eb;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;margin:0 auto 12px;box-shadow:inset 0 2px 4px #0000000d;border:1px solid #bfdbfe}.personnel-profile-header{display:flex;flex-direction:column;align-items:center;margin-bottom:24px}.personnel-profile-name{font-size:20px;font-weight:700;color:#1e293b}.personnel-profile-status{margin-top:8px;padding:4px 12px;border-radius:9999px;font-size:12px;font-weight:500;border-width:1px;border-style:solid}.personnel-info-card{background:#f8fafc;border-radius:12px;padding:16px;border:1px solid #f1f5f9}.personnel-info-item{display:flex;justify-content:space-between;align-items:center;padding-bottom:12px;border-bottom:1px solid #e2e8f0}.personnel-info-item:last-child{padding-bottom:0;border-bottom:none}.personnel-info-label{color:#64748b;display:flex;align-items:center;gap:8px}.personnel-info-label svg{width:16px;height:16px;color:#94a3b8}.personnel-info-value{font-weight:500;color:#1e293b}.personnel-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;font-size:14px}.personnel-form-grid .col-span-2{grid-column:span 2}.personnel-form-label{display:block;font-weight:500;color:#334155;margin-bottom:6px}.personnel-form-input{width:100%;padding:10px;border-radius:12px;border:1px solid #e2e8f0;font-size:14px;color:#334155;outline:none;transition:all .2s;box-shadow:0 1px 2px #0000000d}.personnel-form-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #3b82f61a}.personnel-form-input:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}.personnel-form-select{width:100%;padding:10px;border-radius:12px;border:1px solid #e2e8f0;font-size:14px;color:#334155;background:#fff;outline:none;cursor:pointer;transition:all .2s;box-shadow:0 1px 2px #0000000d}.personnel-form-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #3b82f61a}.personnel-ai-tip{margin-top:20px;padding:16px;background:#ecfdf5;border-radius:12px;display:flex;gap:12px;align-items:flex-start;font-size:14px;border:1px solid #d1fae5}.personnel-ai-tip-icon{width:32px;height:32px;border-radius:50%;background:#d1fae5;display:flex;align-items:center;justify-content:center;flex-shrink:0}.personnel-ai-tip-title{font-weight:600;color:#064e3b;margin-bottom:4px}.personnel-ai-tip-content{color:#047857}.personnel-alert{padding:12px;border-radius:10px;background:#fef3c7;border:1px solid #fde68a;color:#92400e;font-size:14px;margin-bottom:16px;display:flex;align-items:center;gap:8px}.personnel-alert svg{flex-shrink:0}.personnel-attendance-table thead tr{background:#f8fafc;color:#64748b}.personnel-attendance-table thead th{font-weight:500;padding:12px 24px}.personnel-attendance-type{padding:4px 8px;border-radius:6px;font-size:12px}.personnel-attendance-type-absent{background:#fef2f2;color:#dc2626}.personnel-attendance-type-late{background:#fffbeb;color:#d97706}.personnel-attendance-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}.personnel-attendance-btn{padding:4px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.personnel-attendance-btn-approve{background:#ecfdf5;color:#059669}.personnel-attendance-btn-approve:hover{background:#d1fae5}.personnel-attendance-btn-reject{background:#f1f5f9;color:#64748b}.personnel-attendance-btn-reject:hover{background:#e2e8f0}.personnel-org-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.personnel-org-tree{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;border:1px solid #f1f5f9;padding:16px;overflow-y:auto;max-height:600px}.personnel-org-tree-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #f1f5f9}.personnel-org-tree-title{font-weight:700;color:#1e293b}.personnel-org-tree-nodes{display:flex;flex-direction:column;gap:2px;-webkit-user-select:none;user-select:none}.personnel-org-node{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;cursor:pointer;transition:all .2s}.personnel-org-node:hover{background:#f8fafc}.personnel-org-node-selected{background:#eff6ff;color:#1d4ed8}.personnel-org-node-expand{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;cursor:pointer}.personnel-org-node-expand:hover{background:#e2e8f0}.personnel-org-node-expand svg{width:16px;height:16px}.personnel-org-node-name{font-size:14px;font-weight:500}.personnel-org-node-count{font-size:12px;color:#94a3b8;margin-left:auto}.personnel-org-detail{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;border:1px solid #f1f5f9;padding:32px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;position:relative;overflow:hidden}.personnel-org-detail-bg{position:absolute;top:0;right:0;padding:32px;opacity:.05}.personnel-org-detail-bg svg{width:192px;height:192px}.personnel-org-detail-icon{width:80px;height:80px;background:linear-gradient(135deg,#dbeafe,#eef2ff);color:#2563eb;border-radius:24px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;box-shadow:inset 0 2px 4px #0000000d;border:1px solid #bfdbfe}.personnel-org-detail-icon svg{width:40px;height:40px}.personnel-org-detail-title{font-size:24px;font-weight:700;color:#1e293b;letter-spacing:-.025em}.personnel-org-detail-stats{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;margin-top:16px;margin-bottom:32px}.personnel-org-detail-stat{display:flex;flex-direction:column;align-items:center;padding:8px 16px;background:#f8fafc;border-radius:12px;border:1px solid #f1f5f9;min-width:100px}.personnel-org-detail-stat-label{font-size:12px;color:#94a3b8;margin-bottom:4px}.personnel-org-detail-stat-value{font-weight:500;color:#334155}.personnel-org-detail-stat-value-blue{color:#2563eb}.personnel-org-detail-actions{display:flex;flex-wrap:wrap;gap:12px;position:relative;z-index:1}.personnel-sub-dept-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:12px;margin-top:24px}@media(min-width:640px){.personnel-sub-dept-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.personnel-sub-dept-grid{grid-template-columns:repeat(3,1fr)}}.personnel-sub-dept-card{padding:12px;border-radius:12px;border:1px solid #f1f5f9;background:#f8fafc50;cursor:pointer;transition:all .2s}.personnel-sub-dept-card:hover{background:#f8fafc;border-color:#e2e8f0}.personnel-sub-dept-name{font-weight:500;color:#334155;font-size:14px;margin-bottom:4px}.personnel-sub-dept-meta{font-size:12px;color:#64748b;display:flex;justify-content:space-between}.personnel-btn{padding:10px 20px;border-radius:12px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;border:none;font-family:inherit}.personnel-btn svg{width:16px;height:16px}.personnel-btn-primary{background:#2563eb;color:#fff;box-shadow:0 4px 6px -1px #3b82f64d}.personnel-btn-primary:hover{background:#2563eb}.personnel-btn-secondary{background:#fff;border:1px solid #e2e8f0;color:#334155;box-shadow:0 1px 2px #0000000d}.personnel-btn-secondary:hover{background:#f8fafc}.personnel-btn-success{background:#fff;border:1px solid #e2e8f0;color:#059669}.personnel-btn-success:hover{background:#ecfdf5}.personnel-btn-danger{background:#dc2626;color:#fff;box-shadow:0 4px 6px -1px #dc26264d}.personnel-btn-danger:hover{background:#b91c1c}.personnel-btn-success-outline{background:#fff;border:1px solid #e2e8f0;color:#059669}.personnel-btn-success-outline:hover{background:#ecfdf5}.personnel-upload-zone{border:2px dashed #e2e8f0;border-radius:12px;padding:32px;text-align:center;cursor:pointer;transition:all .2s}.personnel-upload-zone:hover{border-color:#2563eb;background:#eff6ff}.personnel-upload-zone svg{width:40px;height:40px;color:#94a3b8;margin:0 auto 12px;transition:color .2s}.personnel-upload-zone:hover svg{color:#2563eb}.personnel-upload-title{font-weight:500;color:#334155;margin-bottom:4px}.personnel-upload-desc{font-size:12px;color:#94a3b8}.personnel-template-card{display:flex;justify-content:space-between;align-items:center;background:#f8fafc;padding:16px;border-radius:12px;border:1px solid #f1f5f9;margin-top:16px}.personnel-template-info{display:flex;align-items:center;gap:12px}.personnel-template-icon{width:32px;height:32px;color:#2563eb;background:#dbeafe;padding:6px;border-radius:8px}.personnel-template-title{font-size:14px;font-weight:500;color:#334155}.personnel-template-desc{font-size:12px;color:#64748b}.personnel-download-btn{color:#2563eb;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:4px;border:none;background:none;font-family:inherit}.personnel-download-btn:hover{color:#2563eb;text-decoration:underline}.personnel-import-modal{max-width:480px}.personnel-flex{display:flex}.personnel-flex-col{display:flex;flex-direction:column}.personnel-flex-wrap{flex-wrap:wrap}.personnel-items-center{align-items:center}.personnel-justify-center{justify-content:center}.personnel-justify-between{justify-content:space-between}.personnel-gap-3{gap:12px}.personnel-gap-4{gap:16px}.personnel-gap-6{gap:24px}.personnel-grid-2{display:grid;grid-template-columns:repeat(2,1fr)}.personnel-col-span-2{grid-column:span 2}.personnel-mb-6{margin-bottom:24px}.personnel-text-red,.personnel-required{color:#ef4444}.personnel-textarea{width:100%;padding:10px;border-radius:12px;border:1px solid #e2e8f0;font-size:14px;color:#334155;outline:none;resize:none;transition:all .2s;box-shadow:0 1px 2px #0000000d}.personnel-textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #3b82f61a}.personnel-textarea::placeholder{color:#94a3b8}.industry-chain-page{padding:30px;background:#f5f7fa;min-height:100%}.industry-chain-tabs{margin-bottom:24px;display:flex;gap:10px;background:#fff;padding:4px;border-radius:8px;width:fit-content;border:1px solid #E5E7EB}.industry-chain-tab-btn{padding:8px 15px;border-radius:6px;border:none;background:transparent;color:#666;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s;display:flex;align-items:center;gap:6px}.industry-chain-tab-btn:hover{background:#f3f4f6;color:#374151}.industry-chain-tab-btn-active,.industry-chain-tab-btn-active:hover{background:#2563eb;color:#fff}.page-container{padding:30px}.page-title{font-size:18px;font-weight:600;margin-bottom:24px}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1050}.modal-content{width:500px;background-color:#fff;border-radius:8px;padding:24px;box-shadow:0 4px 12px #00000026}.modal-title{font-size:18px;font-weight:600;margin-bottom:24px}.modal-content-fixed{display:flex;flex-direction:column;overflow:hidden;max-height:85vh}.modal-content-fixed .modal-title{flex-shrink:0}.modal-content-fixed .modal-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;max-height:60vh}.modal-content-fixed .form-actions{flex-shrink:0;border-top:1px solid #f0f0f0;padding-top:16px;margin-top:16px}.form-item{margin-bottom:16px}.form-label{font-size:13px;color:#666;margin-bottom:6px;display:block}.form-label-required{color:red}.form-input,.form-select{width:100%;padding:8px;border-radius:6px;border:1px solid #E6E6E6;box-sizing:border-box;font-size:14px;transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-select:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 2px #4a90e21a}.form-input::placeholder{color:#bbb}.radio-card-group{display:flex;gap:12px}.radio-card{flex:1;padding:12px;border:1px solid #E6E6E6;border-radius:6px;cursor:pointer;text-align:center;color:#666;transition:all .2s}.radio-card:hover{border-color:#2563eb}.radio-card-active{border-color:#2563eb;background:#e6f0ff;color:#2563eb}.radio-card input{margin-right:6px}.form-actions{display:flex;justify-content:flex-end;gap:12px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin:24px 0}.stat-card{background:var(--bg-card);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-default)}.stat-label{color:#666;font-size:14px;margin-bottom:8px}.stat-value{font-weight:700;color:#333;width:100%;text-align:left;font-size:2.5rem}.stat-value-text{font-weight:700;color:#333;width:100%;text-align:left;font-size:1.1rem}.stat-value-success{color:#7ed321}.stat-value-warning{color:#ff9e7d}.stat-unit{font-size:12px;color:#999;margin-top:8px}.stat-change{font-size:12px;margin-top:8px}.data-table{width:100%;border-collapse:collapse;table-layout:fixed}.data-table th{text-align:left;padding:12px;color:#666;font-size:13px;border-bottom:1px solid #F0F5FF;font-weight:500;white-space:nowrap;background:#fff;background-clip:padding-box}.data-table thead th:hover{background:#fff!important}.data-table thead tr{background:#fff}th.col-actions{text-align:right}th.col-name{text-align:left}th.col-type{text-align:center;width:100px}th.col-icon{text-align:center;width:80px}th.col-component{width:200px}th.col-path{width:150px}th.col-sort{text-align:center;width:60px}th.col-username{width:12%;min-width:100px}th.col-realname{width:10%;min-width:80px}th.col-email{width:18%;min-width:120px}th.col-role{width:12%;min-width:100px}th.col-dept{width:14%;min-width:100px}th.col-status{width:8%;min-width:60px;text-align:center}th.col-lastlogin{width:14%;min-width:100px}.data-table-user{width:100%;table-layout:auto}.data-table-user th.col-username,.data-table-user td.col-username{position:sticky;left:0;z-index:1;background:#fff}.data-table-user tbody tr:hover td.col-username{background:#f5f7fa}.data-table-user thead th.col-username{z-index:2}.data-table-user th.col-actions,.data-table-user td.col-actions{position:sticky;right:0;z-index:10;background:#fff!important}.data-table-user tbody tr:hover td.col-actions{background:#f5f7fa!important}.data-table-user thead th.col-actions{z-index:11}.data-table-user tbody tr:hover td{background:#f5f7fa}.data-table td{padding:16px 12px;border-bottom:1px solid #F0F5FF;vertical-align:middle;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.data-table tbody tr:hover{background:var(--bg-hover)}.status-tag{padding:4px 8px;border-radius:4px;font-size:12px}.status-tag-active{background:#e6f0ff;color:#2563eb}.status-tag-inactive{background:#f5f5f5;color:#999}.status-tag-warning{background:#fff7e6;color:#ff9e7d}.action-link{color:#2563eb;cursor:pointer;margin-right:12px}.action-link:hover{text-decoration:underline}.dropdown-menu{position:absolute;right:0;top:100%;background:#fff;border-radius:6px;box-shadow:0 4px 12px #00000026;min-width:120px;z-index:1100}.dropdown-item{padding:10px 16px;cursor:pointer;transition:background .2s}.dropdown-item:hover{background:var(--bg-hover)}.pagination{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-top:16px;font-size:13px;color:#666}.pagination-left{display:flex;align-items:center;gap:12px}.pagination-right{display:flex;align-items:center;gap:8px}.pagination-select{padding:4px 8px;border-radius:4px;border:1px solid #E6E6E6;font-size:12px;background:#fff;cursor:pointer}.pagination-select:focus{outline:none;border-color:#2563eb}.pagination-input{width:52px;padding:4px 6px;border-radius:4px;border:1px solid #E6E6E6;font-size:12px;text-align:center}.pagination-input:focus{outline:none;border-color:#2563eb}.pagination-input::-webkit-outer-spin-button,.pagination-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.pagination-text{display:flex;align-items:center;gap:6px}.search-bar{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.search-input{flex:1;min-width:200px;padding:8px 12px;border:1px solid #E6E6E6;border-radius:6px}.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:12px}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-xs{gap:4px}.gap-sm{gap:6px}.gap-md{gap:8px}.gap-lg{gap:12px}.table-wrapper{overflow-x:auto;margin-top:16px;-webkit-overflow-scrolling:touch;position:relative;width:100%}.table-wrapper:has(.empty-state),.table-wrapper:has(.no-data){overflow-x:hidden}.table-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#999}.loading-spinner{width:40px;height:40px;border:3px solid #E6F0FF;border-top-color:#2563eb;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#999}.empty-state p{margin-top:16px;font-size:14px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #F0F5FF}.modal-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.modal-close{font-size:24px;color:#999;cursor:pointer;line-height:1}.modal-close:hover{color:#333}.modal-body{max-height:70vh;overflow-y:auto}.form-row{margin-bottom:16px}.form-row .form-label{margin-bottom:6px;font-weight:500}.form-row .form-label.required:before{content:"* ";color:#f5222d}.modal-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid #F0F5FF}.list-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.list-toolbar-left,.list-toolbar-right{display:flex;align-items:center;gap:12px}.list-title{font-size:15px;font-weight:600;color:#333;margin:0}.list-count{font-size:12px;color:#999}.list-search{position:relative}.list-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#999}.list-search-input{padding:6px 12px 6px 30px;border-radius:7px;border:1px solid #E6F0FF;background:#f9fafc;font-size:12px;color:#333;outline:none;width:200px}.filter-group{display:flex;gap:6px}.filter-btn{padding:6px 12px;border-radius:6px;font-size:12px;border:1px solid #E5E7EB;background:#fff;color:#666;cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:#2563eb;color:#2563eb}.filter-btn-active{background:#2563eb;border-color:#2563eb;color:#fff}.filter-divider{width:1px;height:20px;background:#e6e8eb}.table-actions{display:flex;gap:6px}.table-action-btn{font-size:11px;color:#2563eb;background:none;border:none;cursor:pointer;font-family:inherit;padding:2px 0;display:flex;align-items:center;gap:2px}.table-action-btn:hover{text-decoration:underline}.table-action-btn-danger{color:#ef4444}.table-action-btn-warning{color:#ff9e7d;font-weight:600}.tag{font-size:11px;color:#666;background:#f4f5f7;padding:2px 8px;border-radius:4px}.tag-success{background:#d1fae5;color:#065f46}.tag-warning{background:#fef3c7;color:#92400e}.tag-danger{background:#fee2e2;color:#dc2626}.modal-large{width:800px;max-width:90%}.modal-medium{width:600px;max-width:90%}.steps-container{margin-bottom:20px;padding:16px;border-radius:8px;border:1px solid #E5E7EB}.steps-container-inbound{background:#f9fafc}.steps-container-outbound{background:#fef3c7;border-color:#fcd34d}.steps-title{font-size:14px;font-weight:600;margin-bottom:12px}.steps-title-outbound{color:#92400e}.steps-items{display:flex;align-items:center;gap:8px;font-size:12px;color:#6b7280}.step-item{padding:4px 10px;border-radius:12px;font-weight:500}.step-item-active{background:#dbeafe;color:#1d4ed8}.step-item-active-outbound{background:#fef3c7;color:#b45309}.step-item-done{background:#d1fae5;color:#065f46}.step-item-pending{background:#f3f4f6;color:#6b7280}.step-arrow{color:#d1d5db}.doc-no-box{margin-bottom:20px;padding:12px;border-radius:8px;border:1px solid}.doc-no-box-inbound{background:#f0f9ff;border-color:#bae6fd}.doc-no-box-outbound{background:#fef3c7;border-color:#fcd34d}.doc-no-label{font-size:12px;margin-bottom:4px}.doc-no-label-inbound{color:#0369a1}.doc-no-label-outbound{color:#92400e}.doc-no-value{font-size:16px;font-weight:600;font-family:monospace}.doc-no-value-inbound{color:#0c4a6e}.doc-no-value-outbound{color:#78350f}.form-section{margin-bottom:20px}.form-section-label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:12px}.form-section-label-required:before{content:"* ";color:#f5222d}.form-input-group{display:flex;gap:8px}.form-input-full{width:100%;padding:10px 12px;border-radius:6px;border:1px solid #E5E7EB;font-size:14px;outline:none;transition:border-color .2s}.form-input-full:focus{border-color:#2563eb}.form-textarea{width:100%;padding:10px;border:1px solid #E5E7EB;border-radius:6px;font-size:13px;resize:vertical;min-height:80px;outline:none}.form-textarea:focus{border-color:#2563eb}.dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #E5E7EB;border-radius:6px;box-shadow:0 4px 12px #0000001a;max-height:200px;overflow-y:auto;z-index:10;margin-top:4px}.dropdown-item{padding:10px 12px;cursor:pointer;transition:background .2s}.dropdown-item:hover{background:#f3f4f6}.dropdown-item-name{font-size:13px;font-weight:500;color:#333}.dropdown-item-code{font-size:11px;color:#999;font-family:monospace}.type-cards{display:flex;gap:12px}.type-card{flex:1;padding:14px 12px;border-radius:8px;border:2px solid;cursor:pointer;transition:all .2s ease;text-align:center}.type-card-active{border-color:#2563eb;background:#eff6ff}.type-card-active-outbound{border-color:#f59e0b;background:#fffbeb}.type-card-inactive{border-color:#e5e7eb;background:#fff}.type-card-name{font-size:14px;font-weight:600;margin-bottom:4px}.type-card-name-active{color:#2563eb}.type-card-name-active-outbound{color:#f59e0b}.type-card-name-inactive{color:#374151}.type-card-desc{font-size:11px;color:#6b7280}.status-badge{padding:4px 8px;border-radius:4px;font-size:12px}.status-badge-pending{background:#fef3c7;color:#92400e}.status-badge-completed{background:#d1fae5;color:#065f46}.status-badge-processing{background:#dbeafe;color:#1d4ed8}.card{background:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:16px}.card-hover:hover{background:#f9fafc}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.card-title{font-size:14px;font-weight:600;color:#111}.card-meta{font-size:12px;color:#666;display:flex;gap:16px}.module-tags{display:flex;flex-wrap:wrap;gap:8px}.module-tag{padding:4px 8px;background:#f9fafc;color:#999;border-radius:4px;font-size:12px;cursor:pointer;text-decoration:line-through;border:1px solid transparent;transition:all .2s}.module-tag:hover{background:#f0f5ff}.module-tag-selected{background:#e6f0ff;color:#2563eb;text-decoration:none;border-color:#2563eb}.modal-content-wide{width:600px}.form-section-title{font-size:13px;color:#666;margin-bottom:6px}.tenant-name-title{font-size:18px;font-weight:600;margin-bottom:24px}.tenant-table-card .data-table thead th{padding:12px;font-size:13px;color:#666;font-weight:600;background:#fafbfc;border-bottom:1px solid #E6E6E6;white-space:nowrap}.tenant-table-card .data-table thead th:hover{background:#fafbfc!important}.col-name{width:200px}.col-industry,.col-plan{width:80px}.col-expire{width:90px}.col-status{width:60px}.col-actions{width:150px;text-align:right;white-space:normal!important}td.table-cell-right{text-align:right!important}.actions-cell-container{white-space:normal!important;vertical-align:top;overflow:visible!important}.data-table tbody tr,.data-table td.actions-cell-container{overflow:visible!important}.actions-cell{position:relative;z-index:1}.plan-option{position:relative}.plan-option-active{background:#e6f0ff;border-color:#2563eb;color:#2563eb}.dropdown-item-green{color:#52c41a}.dropdown-item-orange{color:#fa8c16}.dropdown-item-purple{color:#722ed1}.dropdown-item-danger{color:#ff4d4f;border-top:1px solid #F0F0F0}.dropdown-item-danger:hover{background:#fff5f5}.dropdown-item-text{font-size:13px;text-align:center}.dropdown-item-text-blue{color:#2563eb}.dropdown-item-text-green{color:#52c41a}.dropdown-item-text-orange{color:#fa8c16}.dropdown-item-text-purple{color:#722ed1}.dropdown-item-text-red{color:#ff4d4f}.table-cell-primary{font-weight:600}.table-cell-default{padding:16px 12px;border-bottom:1px solid #F0F5FF}.table-cell-right{text-align:right}.pagination-toolbar{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding:12px 0}.pagination-info-left{color:#666;font-size:13px}.pagination-controls{display:flex;align-items:center;gap:8px}.pagination-btn-group{display:flex;gap:4px}.pagination-btn-group .pagination-btn{padding:4px 8px;min-width:32px}.pagination-btn-active{background:#2563eb;color:#fff;border-color:#2563eb}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}.tenant-detail-content{padding:8px 0}.detail-row{display:flex;padding:10px 0;border-bottom:1px solid #F0F5FF}.detail-row:last-child{border-bottom:none}.detail-label{width:120px;flex-shrink:0;color:#666;font-size:13px}.detail-value{flex:1;color:#333;font-size:13px;word-break:break-all}.quick-actions{display:inline-flex;align-items:center;gap:4px;margin-right:8px;padding-right:8px;border-right:1px solid #E8E8E8}.quick-action-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:4px;cursor:pointer;transition:all .2s;color:#666}.quick-action-btn:hover{background:#e6f0ff;color:#2563eb}.quick-action-btn svg{display:block}.more-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:4px;cursor:pointer;transition:all .2s}.more-btn:hover{background:#f5f7fa}.compact-actions-wrap{display:flex;flex-direction:column;gap:4px;align-items:flex-end}.compact-actions-row{display:flex;align-items:center;gap:8px}.compact-actions-row-icons{display:flex;align-items:center;gap:0}.compact-actions-row-icons .quick-actions{display:inline-flex;align-items:center;gap:2px;margin-right:4px;padding-right:4px;border-right:1px solid #E8E8E8}.compact-actions-row-icons .quick-action-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:4px;cursor:pointer;transition:all .2s;color:#666}.compact-actions-row-icons .quick-action-btn:hover{background:#e6f0ff;color:#2563eb}.compact-actions-row-icons .more-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:4px;cursor:pointer;transition:all .2s}.compact-actions-row-icons .more-btn:hover{background:#f5f7fa}.org-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{display:flex;align-items:center;gap:16px}.stat-card-wide{display:flex;align-items:center;justify-content:space-between;grid-column:span 2}.stat-icon{padding:12px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center}.stat-icon-1{background:#e6f7ff;color:#1890ff}.stat-icon-2{background:#f6ffed;color:#52c41a}.tenant-select{min-width:200px}.empty-state{padding:40px;text-align:center;color:#8c8c8c}.org-modal-content{width:480px;min-height:400px}.perm-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;background:#fafafa;padding:16px;border-radius:6px}.perm-item{display:flex;align-items:center;gap:8px}.perm-label{cursor:pointer}.form-readonly{padding:8px 12px;border-radius:6px;border:1px solid #d9d9d9;background-color:#f5f5f5;color:#595959}.form-note{font-size:12px;color:#8c8c8c;margin-top:4px}.perm-label{-webkit-user-select:none;user-select:none}.stat-label{width:100px!important;margin-bottom:0!important}.tenant-table-card .table-wrapper{overflow-x:auto;overflow-y:visible;margin-top:16px;-webkit-overflow-scrolling:touch;position:relative;width:100%}.data-table-menu{min-width:860px;table-layout:fixed}.tenant-table-card{overflow:visible!important}.data-table-menu th.col-name{width:24%}.data-table-menu th.col-type,.data-table-menu th.col-icon{width:12%;text-align:center}.data-table-menu th.col-component{width:24%}.data-table-menu th.col-path{width:20%}.data-table-menu th.col-sort{width:8%;text-align:center}.data-table-menu th.col-actions{width:22%;text-align:right}.data-table-menu thead th{padding:12px;font-size:13px;color:#666;font-weight:600;background:#fafbfc;border-bottom:1px solid #E6E6E6;white-space:nowrap}.data-table-menu thead th:hover{background:#fafbfc!important}.data-table-menu td.col-component,.data-table-menu td.col-path{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:0}.data-table-menu td.col-path .col-path-inner{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-table-menu th.col-name{position:sticky;left:0;z-index:11;background:#fafbfc}.data-table-menu td.col-name{position:sticky;left:0;z-index:10;background:#fff}.data-table-menu tbody tr:hover td.col-name{background:var(--bg-hover)}.data-table-menu th.col-actions{position:sticky;right:0;z-index:11;background:#fafbfc;min-width:120px}.data-table-menu td.col-actions{position:sticky;right:0;z-index:10;background:#fff;min-width:120px}.data-table-menu tbody tr:hover td.col-actions{background:var(--bg-hover)}.form-radio-group{display:flex;flex-wrap:wrap;gap:16px 24px;align-items:center}.form-radio-label{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-weight:400;-webkit-user-select:none;user-select:none}.form-radio{width:16px;height:16px;margin:0;cursor:pointer;accent-color:var(--primary-color, #1890ff)}.toast-container{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 20px;border-radius:8px;font-size:14px;box-shadow:0 4px 12px #00000026;animation:toast-fade-in .3s ease;pointer-events:auto;min-width:200px;max-width:400px}.toast-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:12px;font-weight:700;flex-shrink:0}.toast-message{flex:1;line-height:1.5}.toast-success{background:linear-gradient(135deg,#f6ffed,#d9f7be);border:1px solid #B7EB8F;color:#389e0d}.toast-success .toast-icon{background:#52c41a;color:#fff}.toast-error{background:linear-gradient(135deg,#fff1f0,#ffccc7);border:1px solid #FFA39E;color:#cf1322}.toast-error .toast-icon{background:#ff4d4f;color:#fff}.toast-warning{background:linear-gradient(135deg,#fffbe6,#ffe58f);border:1px solid #FFE58F;color:#d48806}.toast-warning .toast-icon{background:#faad14;color:#fff}.toast-info{background:linear-gradient(135deg,#e6f7ff,#bae7ff);border:1px solid #91D5FF;color:#0958d9}.toast-info .toast-icon{background:#1890ff;color:#fff}@keyframes toast-fade-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}:root{--color-primary: #2563EB;--color-primary-light: #60A5FA;--color-primary-tint: #EFF6FF;--color-success: #22C55E;--color-warning: #F59E0B;--color-danger: #EF4444;--bg-page: #F9FAFC;--bg-card: #FFFFFF;--bg-hover: #F0F5FF;--text-primary: #333333;--text-secondary: #666666;--text-tertiary: #999999;--text-white: #FFFFFF;--shadow-default: 0 2px 8px rgba(59, 130, 246, .08);--shadow-hover: 0 4px 16px rgba(59, 130, 246, .12);--shadow-modal: 0 8px 32px rgba(59, 130, 246, .16);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease-out;--spacing-xs: 8px;--spacing-sm: 16px;--spacing-md: 24px;--spacing-lg: 32px;--spacing-xl: 40px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--sidebar-width: 240px;--sidebar-collapsed: 64px;--topbar-height: 56px;--rightpanel-width: 300px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:Inter,PingFang SC,Helvetica Neue,Arial,sans-serif;font-size:14px;color:var(--text-primary);background:var(--bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#3b82f633;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#3b82f666}a{color:var(--color-primary);text-decoration:none}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,textarea{font-family:inherit;outline:none}.gradient-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%)}@keyframes countUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.animate-fade-in-up{animation:fadeInUp var(--transition-normal) both}.animate-count-up{animation:countUp .8s ease both}
