.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}}.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}.page-container{padding:30px}.page-box{padding:30px;background:#f9fafc;min-height:100%}.page-title{font-size:18px;font-weight:600;margin-bottom:24px}.tab-group{margin-bottom:20px;display:flex;gap:4px;background:#fff;padding:4px;border-radius:8px;width:fit-content;border:1px solid #E5E7EB}.tab-btn{padding:8px 16px;border-radius:6px;border:none;background:transparent;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s ease;display:flex;align-items:center;gap:6px}.tab-btn:hover{background:#f3f4f6;color:#374151}.tab-btn-active,.tab-btn-active:hover{background:#2563eb;color:#fff}.tab-group-sm{display:flex;gap:8px;background:#fff;padding:4px;border-radius:8px;border:1px solid #E5E7EB}.tab-btn-sm{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}.tab-btn-sm:hover{background:#f3f4f6;color:#374151}.tab-btn-sm-active,.tab-btn-sm-active:hover{background:#2563eb;color:#fff}.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-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;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;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;margin-bottom:10px}.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}.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}.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}.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}.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.toolbar-filters,.toolbar-row{display:flex;gap:12px;align-items:center}.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}.search-input-icon-wrapper{position:relative;display:flex;align-items:center}.search-input-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#999;pointer-events:none}.search-input-with-icon{width:100%;padding:6px 12px 6px 30px;border-radius:7px;border:1px solid #E6F0FF;background:#f9fafc;font-size:14px;color:#333;outline:none;transition:border-color .2s}.search-input-with-icon:focus{border-color:#2563eb}.table-base{width:100%;border-collapse:collapse}.table-base th{text-align:left;padding:11px 16px 11px 0;color:#666;font-size:13px;border-bottom:1px solid #F0F5FF;font-weight:500;white-space:nowrap;background:#fff}.table-base th:hover{background:#fff!important}.table-base td{padding:11px 16px 11px 0;font-size:12px;border-bottom:1px solid #F9FAFC;vertical-align:middle;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table-base tbody tr:hover td{background:#f9fafc}.table-cell-code{color:#2563eb;font-weight:600}.table-cell-name{color:#333;font-weight:500}.table-cell-remark{color:#666}.table-cell-date{color:#999}.table-cell-qty{color:#333;font-weight:600}.table-cell-qty span{color:#999;font-weight:400}.table-cell-actions{padding:11px 0;display:flex;gap:6px}.table-cell-tag{font-size:11px;color:#666;background:#f4f5f7;padding:2px 8px;border-radius:4px}.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;transition:border-color .2s}.filter-select:focus{border-color:#2563eb}.filter-label{font-size:12px;color:#666;white-space:nowrap}.filter-divider{width:1px;height:20px;background:#e6e8eb}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.alert-card{border-radius:12px;padding:16px 20px;margin-bottom:20px;display:flex;align-items:flex-start;gap:10px}.alert-card-info{background:linear-gradient(135deg,#fff2ec,#fff8f5);border:1px solid #FFD5C0}.alert-card-warning{background:#fffbeb;border:1px solid #FDE68A}.alert-card-title{font-size:13px;font-weight:700;margin-bottom:4px}.alert-card-info .alert-card-title{color:#d45a30}.alert-card-warning .alert-card-title{color:#92400e}.alert-card-desc{font-size:12px;color:#666;line-height:1.6}.alert-card-btn{padding:8px 16px;border-radius:8px;border:none;color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .2s;flex-shrink:0}.alert-card-btn:hover{opacity:.9}.modal-container{background-color:#fff;border-radius:12px;width:960px;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;border-bottom:1px solid #E5E7EB;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.modal-header h3{margin:0;font-size:18px;font-weight:600;color:#111827}.modal-close-btn{border:none;background:transparent;cursor:pointer;color:#9ca3af;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close-btn:hover{color:#6b7280}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid #E5E7EB;background:#f9fafc;display:flex;justify-content:flex-end;gap:12px;flex-shrink:0}.pagination-bar{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-btns{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}.empty-hint{text-align:center;padding:40px 20px;color:#9ca3af;font-size:14px}.form-required{color:#ef4444}.form-row{display:flex;gap:16px}.form-row>div{flex:1}.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 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-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}.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}.dropdown-portal{min-height:40px}.dropdown-portal::-webkit-scrollbar{width:6px}.dropdown-portal::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.dropdown-portal::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.dropdown-portal::-webkit-scrollbar-thumb:hover{background:#a1a1a1}
