html,body,#root{width:100%;height:100%;margin:0;overflow:hidden;background:#f5f7fb}*{box-sizing:border-box}*{scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:#cbd5e1;border:2px solid transparent;border-radius:999px;background-clip:content-box}*::-webkit-scrollbar-thumb:hover{background:#94a3b8;border:2px solid transparent;background-clip:content-box}.app-shell{height:100vh;overflow:hidden}.app-sider{border-right:1px solid #e7ebf2;background:#fff!important}.app-logo{height:56px;display:flex;align-items:center;gap:10px;padding:0 18px;border-bottom:1px solid #eef1f6;font-weight:700;color:#1f2937}.app-logo-mark{width:26px;height:26px;border-radius:6px;background:#1677ff;color:#fff;display:inline-flex;align-items:center;justify-content:center}.app-header{height:56px;padding:0 20px;background:#fff;border-bottom:1px solid #e7ebf2;display:flex;align-items:center;justify-content:space-between}.app-content{height:calc(100vh - 56px);overflow:hidden;padding:16px}.page{height:100%;min-height:0;display:flex;flex-direction:column;gap:12px}.page-title{display:flex;align-items:center;justify-content:space-between;flex:0 0 auto}.page-title h1{margin:0;font-size:20px;line-height:28px}.filter-bar{flex:0 0 auto;padding:12px;background:#fff;border:1px solid #e7ebf2;border-radius:6px}.table-panel{flex:1 1 auto;min-height:0;padding:12px;background:#fff;border:1px solid #e7ebf2;border-radius:6px;overflow:hidden}.table-panel .ant-table-wrapper,.table-panel .ant-spin-nested-loading,.table-panel .ant-spin-container{height:100%;min-height:0}.table-panel .ant-spin-container{display:flex;flex-direction:column}.table-panel .ant-table{flex:1 1 auto;min-height:0;border-radius:6px}.table-panel .ant-table-container{height:100%;display:flex;flex-direction:column}.table-panel .ant-table-body{flex:1 1 auto;min-height:0;overflow:auto!important;scrollbar-gutter:stable}.table-panel .ant-table-placeholder .ant-table-cell{border-bottom:0}.table-panel .ant-pagination{flex:0 0 auto;margin:12px 4px 0}.login-page{height:100vh;display:grid;place-items:center;background:#f5f7fb}.login-panel{width:380px;padding:28px;background:#fff;border:1px solid #e7ebf2;border-radius:8px;box-shadow:0 16px 38px #0f172a14}.payment-test-layout{flex:1 1 auto;min-height:0;display:grid;grid-template-columns:minmax(360px,460px) minmax(0,1fr);gap:12px}.payment-test-panel{min-height:0;overflow:auto;padding:14px;background:#fff;border:1px solid #e7ebf2;border-radius:6px}.payment-test-form{margin-top:14px}.payment-test-result{display:flex;flex-direction:column;gap:14px}.result-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.result-header h2{margin:0;font-size:16px;line-height:24px}.payment-qrcode{display:grid;grid-template-columns:240px minmax(0,1fr);gap:16px;align-items:center;padding:16px;border:1px solid #e7ebf2;border-radius:6px}.payment-link-panel{padding:16px;border:1px solid #e7ebf2;border-radius:6px;background:#fbfcff}.payment-url{max-width:100%}.empty-result{flex:1 1 auto;min-height:240px;display:grid;place-items:center;border:1px dashed #d6deea;border-radius:6px;background:#fbfcff}
