.login-page{background:linear-gradient(135deg,#2563eb 0%,#1e40af 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:32px 24px;display:flex}.login-logo{color:#2563eb;background:#fff;border-radius:20px;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:24px;font-size:40px;font-weight:900;display:flex;box-shadow:0 8px 24px #0003}.login-title{color:#fff;margin-bottom:8px;font-size:28px;font-weight:800}.login-subtitle{color:#fffc;margin-bottom:40px;font-size:15px}.login-form{width:100%;max-width:340px}.login-input{box-sizing:border-box;background:#fffffff2;border:none;border-radius:12px;outline:none;width:100%;height:50px;margin-bottom:16px;padding:0 16px;font-size:16px}.login-btn{color:#2563eb;cursor:pointer;background:#fff;border:none;border-radius:12px;width:100%;height:50px;margin-top:8px;font-size:17px;font-weight:700;transition:transform .1s}.login-btn:active{transform:scale(.98)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-error{color:#FCA5A;text-align:center;margin-bottom:12px;font-size:14px}.login-tip{text-align:center;color:#fff9;margin-top:32px;font-size:12px}.status-bar{color:#fff;z-index:100;background:#2563eb;justify-content:space-between;align-items:center;height:44px;padding:0 16px;font-size:14px;font-weight:600;display:flex;position:sticky;top:0}.nav-bar{z-index:100;background:#fff;border-bottom:1px solid #e2e8f0;align-items:center;height:56px;padding:0 16px;display:flex;position:sticky;top:44px}.home-header{margin-bottom:32px}.doclib-page{background:#f1f5f9;min-height:100vh;padding-bottom:100px}.tab-scroll{-webkit-overflow-scrolling:touch;scrollbar-width:none;background:#fff;border-bottom:1px solid #e2e8f0;gap:8px;padding:12px 16px;display:flex;overflow-x:auto}.tab-scroll::-webkit-scrollbar{display:none}.tab-item{color:#64748b;cursor:pointer;white-space:nowrap;background:#f1f5f9;border:none;border-radius:20px;flex-shrink:0;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s}.tab-item.active{color:#fff;background:#2563eb;font-weight:600}.card-list{padding:12px 16px}.data-card{cursor:pointer;background:#fff;border-left:4px solid #2563eb;border-radius:12px;margin-bottom:12px;padding:16px;transition:all .2s;box-shadow:0 2px 8px #00000014}.data-card:active{transform:scale(.98)}.card-header{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.card-code{color:#2563eb;font-family:SF Mono,Menlo,monospace;font-size:14px;font-weight:600}.card-status{border-radius:12px;padding:4px 10px;font-size:12px;font-weight:600}.status-draft{color:#d97706;background:#fef3c7}.status-pending{color:#2563eb;background:#dbeafe}.status-approved{color:#059669;background:#d1fae5}.status-rejected{color:#dc2626;background:#fee2e2}.card-body{flex-direction:column;gap:8px;display:flex}.card-row{justify-content:space-between;align-items:center;font-size:14px;display:flex}.card-label{color:#64748b;font-size:13px}.card-value{color:#0f172a;text-align:right;flex:1;margin-left:12px;font-weight:500}.card-footer{color:#64748b;border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;font-size:12px;display:flex}.fab{color:#fff;cursor:pointer;z-index:99;background:#2563eb;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;transition:all .2s;display:flex;position:fixed;bottom:100px;right:20px;box-shadow:0 4px 12px #2563eb66}.fab:active{transform:scale(.9)}.empty-state{text-align:center;color:#64748b;padding:60px 32px}.empty-icon{opacity:.5;margin-bottom:16px;font-size:64px}.empty-text{font-size:15px}.bom-form-page{background:#f1f5f9;min-height:100vh;padding-bottom:120px}.step-indicator{background:#fff;border-bottom:1px solid #e2e8f0;gap:8px;padding:16px;display:flex}.step-item{text-align:center;color:#64748b;cursor:pointer;border-bottom:3px solid #0000;flex:1;padding-bottom:8px;font-size:12px;font-weight:600;transition:all .2s}.step-item.active{color:#2563eb;border-bottom-color:#2563eb}.step-item.done{color:#10b981;border-bottom-color:#10b981}.form-body{padding:16px}.form-section{background:#fff;border-radius:12px;margin-bottom:16px;padding:16px;box-shadow:0 2px 8px #00000014}.section-title{color:#0f172a;border-bottom:2px solid #2563eb;margin-bottom:16px;padding-bottom:12px;font-size:16px;font-weight:700}.section-subtitle{color:#0f172a;margin:16px 0 12px;font-size:14px;font-weight:700}.form-row{margin-bottom:16px}.form-label{color:#0f172a;align-items:center;gap:4px;margin-bottom:8px;font-size:14px;font-weight:600;display:flex}.required{color:#ef4444;font-weight:700}.form-input{box-sizing:border-box;border:2px solid #e2e8f0;border-radius:8px;outline:none;width:100%;height:44px;padding:0 12px;font-size:15px;transition:all .2s}.form-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-select{appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%2364748B'/%3E%3C/svg%3E") right 12px center no-repeat;border:2px solid #e2e8f0;border-radius:8px;outline:none;width:100%;height:44px;padding:0 12px;font-size:15px}.item-card{border:2px solid #e2e8f0;border-radius:8px;margin-bottom:12px;padding:16px}.item-header{justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px;font-weight:600;display:flex}.btn-remove{color:#ef4444;cursor:pointer;background:#fee2e2;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.btn-add{color:#2563eb;cursor:pointer;background:0 0;border:2px dashed #2563eb;border-radius:8px;width:100%;height:44px;margin-top:12px;font-size:15px;font-weight:600;transition:all .2s}.btn-add:active{background:#dbeafe}.upload-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.upload-zone{text-align:center;cursor:pointer;background:#f8fafc;border:2px dashed #e2e8f0;border-radius:8px;padding:20px 8px;transition:all .2s}.upload-zone:active{background:#dbeafe;border-color:#2563eb}.upload-icon{margin-bottom:8px;font-size:32px}.upload-text{color:#64748b;font-size:12px}.bottom-actions{z-index:99;width:100%;max-width:390px;padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid #e2e8f0;gap:12px;display:flex;position:fixed;bottom:64px;left:50%;transform:translate(-50%)}.btn{cursor:pointer;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;height:44px;font-size:15px;font-weight:600;transition:all .2s;display:flex}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.7;cursor:not-allowed}.btn-primary{color:#fff;background:#2563eb}.btn-secondary{color:#0f172a;background:#f1f5f9;border:2px solid #e2e8f0}.btn-success{color:#fff;background:#10b981}.dashboard-page{background:#f1f5f9;min-height:100vh;padding-bottom:100px}.metric-grid{grid-template-columns:repeat(2,1fr);gap:12px;padding:16px;display:grid}.metric-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014}.metric-label{color:#64748b;margin-bottom:8px;font-size:13px}.metric-value{color:#0f172a;font-size:28px;font-weight:800}.metric-change{margin-top:4px;font-size:12px;font-weight:600}.change-up{color:#10b981}.change-down{color:#ef4444}.chart-placeholder{background:#f1f5f9;border-radius:8px;justify-content:center;align-items:center;height:200px;padding:16px;display:flex}.bar-chart{align-items:flex-end;gap:8px;width:100%;height:100%;display:flex}.bar-wrapper{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.bar{background:linear-gradient(#2563eb 0%,#1e40af 100%);border-radius:4px 4px 0 0;width:100%;min-height:4px;transition:height .3s}.bar-label{color:#64748b;margin-top:4px;font-size:10px}.record-row{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:12px 0;font-size:14px;display:flex}.record-code{color:#2563eb;font-family:SF Mono,Menlo,monospace;font-size:13px;font-weight:600}.record-name{color:#0f172a;flex:1;margin:0 12px}.record-status{font-size:16px}.status-approved{color:#10b981}.status-pending{color:#2563eb}.status-draft{color:#f59e0b}.profile-page{background:#f1f5f9;min-height:100vh;padding-bottom:100px}.profile-menu{background:#fff;border-radius:12px;margin-bottom:12px;overflow:hidden;box-shadow:0 2px 8px #00000014}.profile-menu-item{cursor:pointer;color:#0f172a;border-bottom:1px solid #e2e8f0;align-items:center;gap:12px;padding:16px;font-size:15px;transition:background .2s;display:flex}.profile-menu-item:last-child{border-bottom:none}.profile-menu-item:active{background:#f1f5f9}.home-page{background:#f1f5f9;min-height:100vh;padding:24px 16px 100px}.status-bar{color:#fff;z-index:100;background:#2563eb;justify-content:space-between;align-items:center;height:44px;margin:-24px -16px 0;padding:0 16px;font-size:14px;font-weight:600;display:flex;position:sticky;top:0}.nav-bar{z-index:100;background:#fff;border-bottom:1px solid #e2e8f0;align-items:center;height:56px;margin:0 -16px;padding:0 16px;display:flex;position:sticky;top:44px}.nav-title{text-align:center;flex:1;font-size:18px;font-weight:700}.nav-btn{cursor:pointer;color:#0f172a;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.home-header{margin-top:16px;margin-bottom:32px}.home-greeting{color:#64748b;margin-bottom:4px;font-size:14px}.home-username{color:#0f172a;font-size:24px;font-weight:800}.home-cards{flex-direction:column;gap:16px;display:flex}.home-card{cursor:pointer;background:#fff;border-left:6px solid #2563eb;border-radius:16px;align-items:center;gap:20px;padding:24px;transition:all .2s;display:flex;box-shadow:0 2px 8px #00000014}.home-card:active{transform:scale(.98);box-shadow:0 2px 8px #0000001a}.home-card-icon{background:#dbeafe;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;display:flex}.home-card-body{flex:1}.home-card-title{color:#0f172a;margin-bottom:4px;font-size:18px;font-weight:700}.home-card-desc{color:#64748b;font-size:13px}.home-card-arrow{color:#64748b;font-size:20px}.tab-bar{width:100%;max-width:390px;height:64px;padding-bottom:env(safe-area-inset-bottom);z-index:100;background:#fff;border-top:1px solid #e2e8f0;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.tab-bar-item{cursor:pointer;color:#64748b;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;padding:8px 0;font-size:10px;font-weight:500;transition:all .2s;display:flex}.tab-bar-item.active{color:#2563eb}.tab-bar-icon{font-size:24px}*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1677ff;--primary-bg:#e6f4ff;--success:#00b578;--warning:#ff8f1f;--danger:#ff3141;--bg:#f5f5f5;--card-bg:#fff;--text:#333;--text-secondary:#999;--border:#eee;--sidebar-w:200px;--rightbar-w:280px}html,body,#root{background:var(--bg);height:100%;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,sans-serif}.mobile-layout{flex-direction:column;height:100%;display:flex}.mobile-layout .main-content{flex:1;padding:12px;overflow-y:auto}.mobile-layout .bottom-tab{border-top:1px solid var(--border);background:var(--card-bg);padding:4px 0 env(safe-area-inset-bottom,4px);display:flex}.pc-layout{height:100%;display:flex}.pc-layout .sidebar{width:var(--sidebar-w);background:var(--card-bg);border-right:1px solid var(--border);overflow-y:auto}.pc-layout .main-content{flex:1;padding:16px;overflow-y:auto}.pc-layout .rightbar{width:var(--rightbar-w);background:var(--card-bg);border-left:1px solid var(--border);overflow-y:auto}.page-loading{height:100%;color:var(--text-secondary);justify-content:center;align-items:center;display:flex}
