:root{color:#172033;background:#f4f6fb;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,Arial,sans-serif;font-variant-numeric:tabular-nums}*{box-sizing:border-box}body{margin:0;min-height:100vh}button,input,select,textarea{font:inherit}.auth{min-height:100vh;display:grid;place-items:center;padding:20px;background:linear-gradient(135deg,#eef4ff,#f4f6fb 60%)}.auth-card{width:100%;max-width:380px;background:#fff;border:1px solid #e4e9f2;border-radius:14px;box-shadow:0 24px 48px #1a23341a;padding:28px 28px 24px}.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:22px}.auth-brand .mark{width:40px;height:40px;border-radius:10px;background:#1478f0;color:#fff;display:grid;place-items:center;font-weight:800;font-size:18px}.auth-brand .title{font-weight:800;font-size:16px}.auth-brand .subtitle{margin-top:2px;color:#718096;font-size:12px}.auth-form{display:grid;gap:14px}.auth-hint{font-size:12px;color:#5d6b82;background:#f1f5f9;border-radius:8px;padding:10px 12px}.shell{display:grid;grid-template-columns:220px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;background:#0f172a;color:#cbd5f5;display:flex;flex-direction:column}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:20px 22px;border-bottom:1px solid rgba(255,255,255,.07)}.sidebar-brand .mark{width:34px;height:34px;border-radius:8px;background:#1478f0;color:#fff;display:grid;place-items:center;font-weight:800}.sidebar-brand .title{font-weight:800;color:#fff;font-size:15px}.sidebar-brand .subtitle{margin-top:2px;font-size:11px;color:#94a3b8}.sidebar-menu{flex:1;padding:14px 12px;display:grid;gap:2px;align-content:start}.menu-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;border:0;background:transparent;color:#cbd5f5;width:100%;text-align:left;cursor:pointer;font-weight:600;font-size:13px}.menu-item:hover{background:#ffffff0f;color:#fff}.menu-item.active{background:#1478f0;color:#fff}.menu-item .icon{width:18px;text-align:center;font-size:14px;opacity:.85}.sidebar-footer{padding:14px 18px;border-top:1px solid rgba(255,255,255,.07);font-size:11px;color:#94a3b8}.app-main{display:flex;flex-direction:column;min-width:0}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:18px;height:60px;padding:0 24px;border-bottom:1px solid #e4e9f2;background:#fffffff0;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.page-title{font-weight:800;font-size:15px}.user-chip{display:flex;align-items:center;gap:10px}.user-chip .avatar{width:30px;height:30px;border-radius:999px;background:#1478f0;color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px}.user-chip .meta{display:grid;line-height:1.25}.user-chip .meta .name{font-weight:700;font-size:13px}.user-chip .meta .role{font-size:11px;color:#718096}.content{padding:22px 24px 32px;display:grid;gap:18px;align-content:start}.panel{border:1px solid #e4e9f2;border-radius:10px;background:#fff;box-shadow:0 8px 24px #1a23340d}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;border-bottom:1px solid #edf1f7;min-height:48px}.panel-title{font-weight:700;font-size:13px;color:#0f172a;display:flex;align-items:center;gap:8px}.panel-title .badge-count{font-size:11px;font-weight:600;color:#64748b;background:#f1f5f9;padding:1px 8px;border-radius:999px}.panel-body{padding:16px}.panel-body.tight{padding:0}.stack{display:grid;gap:14px}.row{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width: 720px){.row{grid-template-columns:1fr}}.field{display:grid;gap:6px}.field label{color:#5d6b82;font-size:12px;font-weight:700}.field input,.field select,.field textarea{width:100%;border:1px solid #d9e1ec;border-radius:8px;background:#fff;padding:10px 12px;outline:none}.field input:focus,.field select:focus,.field textarea:focus{border-color:#1478f0;box-shadow:0 0 0 3px #1478f01f}.actions{display:flex;gap:10px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;border:1px solid #d9e1ec;border-radius:6px;background:#fff;color:#334155;height:30px;padding:0 12px;cursor:pointer;font-size:12px;font-weight:600;white-space:nowrap;line-height:1;transition:background .15s,border-color .15s}.btn:hover{background:#f7f9fc;border-color:#cbd5e1}.btn.primary{border-color:#1478f0;background:#1478f0;color:#fff}.btn.primary:hover{background:#0f63cf;border-color:#0f63cf}.btn.danger{border-color:#fecdd3;color:#be123c}.btn.danger:hover{background:#fff1f2;border-color:#fda4af}.btn.ghost{border:0;background:transparent;color:#5d6b82;padding:0 8px}.btn.ghost:hover{background:#f1f5f9;color:#0f172a}.btn:disabled{cursor:not-allowed;opacity:.5}.btn.block{width:100%;height:36px}.btn.lg{height:36px;padding:0 16px;font-size:13px}.btn-row{display:inline-flex;gap:4px}.btn-row .btn{height:26px;padding:0 10px;font-size:11px;font-weight:600}.message{border-radius:8px;padding:10px 12px;font-size:13px;color:#155e75;background:#ecfeff}.message.error{color:#be123c;background:#fff1f2}.message.warn{color:#92400e;background:#fef3c7}.codes{display:grid;gap:8px}.code{display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid #dbeafe;border-radius:8px;background:#eff6ff;padding:9px 10px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px}table{min-width:720px;width:100%;border-collapse:collapse;font-size:12.5px}.table-wrap{overflow-x:auto}th,td{border-bottom:1px solid #edf1f7;padding:8px 12px;text-align:left;vertical-align:middle}th{color:#64748b;background:#f8fafc;font-size:11px;font-weight:700;letter-spacing:.4px;white-space:nowrap}tbody tr:hover{background:#f8fafc}code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px}.copy-cell{display:grid;gap:4px;min-width:160px;max-width:280px;overflow-wrap:anywhere}.copyable{display:inline-block;padding:3px 6px;margin:-3px -6px;border-radius:4px;cursor:pointer;transition:background .12s ease,color .12s ease,box-shadow .12s ease;-webkit-user-select:all;user-select:all}.copyable:hover{background:#eff6ff;color:#1478f0}.copyable:active{background:#dbeafe;box-shadow:inset 0 0 0 1px #93c5fd}.product-tag{display:inline-flex;margin:0 6px 6px 0;border-radius:999px;background:#f1f5f9;color:#334155;padding:3px 8px;font-size:12px;font-weight:700}.empty{padding:32px 12px;color:#94a3b8;text-align:center}.muted{color:#718096}.pill{display:inline-flex;align-items:center;border-radius:999px;background:#eef2ff;color:#3730a3;padding:2px 8px;font-size:12px;font-weight:700}.pill.success{background:#ecfdf5;color:#047857}.pill.danger{background:#fff1f2;color:#be123c}.pill.muted-pill{background:#f1f5f9;color:#64748b}.pill.warn{background:#fef3c7;color:#92400e}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.stat{background:#fff;border:1px solid #e4e9f2;border-radius:10px;padding:16px 18px;display:grid;gap:6px}.stat .label{color:#5d6b82;font-size:12px;font-weight:700}.stat .value{font-size:24px;font-weight:800;color:#0f172a}.stat .hint{color:#94a3b8;font-size:11px}.toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 16px;background:#fafbfc;border-bottom:1px solid #edf1f7}.toolbar-label{color:#64748b;font-size:11px;font-weight:700;margin-right:2px;letter-spacing:.4px}.form-control{height:30px;padding:0 10px;border:1px solid #d9e1ec;border-radius:6px;background:#fff;font-size:12px;color:#0f172a;outline:none;transition:border-color .15s,box-shadow .15s;min-width:0}.form-control:focus{border-color:#1478f0;box-shadow:0 0 0 3px #1478f01f}.form-control.is-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'><path d='M2 4l3 3 3-3' fill='none' stroke='%2364748b' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 8px center;padding-right:24px}.form-control[type=search],.form-control.is-search{padding-left:28px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><circle cx='5' cy='5' r='3.2' fill='none' stroke='%2394a3b8' stroke-width='1.4'/><path d='M7.5 7.5l2 2' stroke='%2394a3b8' stroke-width='1.4' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:9px center}.toolbar .form-control{min-width:100px}.toolbar .form-control.w-sm{min-width:120px}.toolbar .form-control.w-md{min-width:180px}.toolbar .form-control.w-lg{flex:1;min-width:220px}.toolbar .divider{width:1px;height:18px;background:#e4e9f2;margin:0 2px}.toolbar .spacer{flex:1}.pager{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:12px 18px;background:#f8fafc;border-top:1px solid #edf1f7;font-size:12px;color:#5d6b82}.pager-info b{color:#0f172a}.pager-actions{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.pager-num{min-width:30px;height:28px;padding:0 8px;border:1px solid #d9e1ec;background:#fff;color:#283447;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600}.pager-num:hover:not(:disabled):not(.active){background:#f1f5f9}.pager-num.active{border-color:#1478f0;background:#1478f0;color:#fff;cursor:default}.pager-num:disabled{cursor:not-allowed;color:#cbd5e1;background:#fff}.pager-ellipsis{min-width:24px;display:inline-flex;align-items:center;justify-content:center;color:#94a3b8}.pager-jump{display:inline-flex;align-items:center;gap:4px;margin-left:6px;color:#5d6b82}.pager-jump input{width:56px;height:28px;padding:0 6px;border:1px solid #d9e1ec;border-radius:6px;outline:none;font-size:12px;text-align:center}.pager-jump input:focus{border-color:#1478f0;box-shadow:0 0 0 3px #1478f01f}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 14px}.form-field{display:grid;gap:4px;min-width:0}.form-field label{font-size:11px;font-weight:700;color:#64748b;letter-spacing:.4px}.form-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:14px}.generated-chip{display:inline-flex;align-items:center;gap:8px;padding:4px 10px 4px 12px;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af;font-size:12px}.generated-chip b{color:#0f172a}@media (max-width: 720px){.form-grid{grid-template-columns:1fr}.form-grid>.form-field[style]{grid-column:auto!important}}tr.row-new{background:#fffbeb}tr.row-new td:nth-child(2){border-left:3px solid #f59e0b}#toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;align-items:flex-end;gap:8px;pointer-events:none}.toast{pointer-events:auto;display:inline-flex;align-items:center;min-width:220px;max-width:360px;padding:10px 14px;border-radius:8px;font-size:13px;font-weight:600;border:1px solid transparent;background:#fff;color:#0f172a;box-shadow:0 12px 28px #0f172a2e;opacity:0;transform:translate(16px);transition:opacity .2s ease,transform .2s ease;cursor:pointer}.toast.toast-show{opacity:1;transform:translate(0)}.toast-info{color:#155e75;background:#ecfeff;border-color:#a5f3fc}.toast-error{color:#be123c;background:#fff1f2;border-color:#fecdd3}.toast-warn{color:#92400e;background:#fef3c7;border-color:#fde68a}.text-link{background:none;border:0;padding:0;font-size:12.5px;color:#1478f0;cursor:pointer;font-weight:600;margin-right:12px}.text-link:hover{color:#0f63cf;text-decoration:underline}.text-link.danger{color:#be123c}.text-link.danger:hover{color:#9f1239}.text-link:disabled{color:#94a3b8;cursor:not-allowed;text-decoration:none}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:9000;display:grid;place-items:center;padding:20px;animation:modal-fade .15s ease}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}.modal{width:100%;max-width:460px;background:#fff;border-radius:10px;box-shadow:0 24px 48px #0f172a40;overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - 40px)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;border-bottom:1px solid #e4e9f2}.modal-title{font-weight:700;font-size:14px;color:#0f172a}.modal-x{height:28px;width:28px;padding:0;font-size:14px;line-height:1}.modal-body{padding:18px;display:grid;gap:12px;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 18px;border-top:1px solid #e4e9f2;background:#fafbfc}th.select-col,td.select-col{width:36px;padding:8px 0 8px 14px;text-align:left}.row-check{width:14px;height:14px;margin:0;cursor:pointer;accent-color:#1478f0}.selection-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:8px 16px;background:#eff6ff;border-bottom:1px solid #bfdbfe;font-size:12px;color:#1e3a8a}.selection-bar-count b{color:#0f172a;font-weight:800}.selection-bar .btn-row{margin-left:auto}tr.row-edit{background:#eff6ff}tr.row-edit input,tr.row-edit select{width:100%;border:1px solid #c7d2fe;border-radius:6px;padding:5px 8px;font-size:12px;outline:none}tr.row-edit input:focus,tr.row-edit select:focus{border-color:#1478f0;box-shadow:0 0 0 2px #1478f02e}.dict-shell{display:grid;grid-template-columns:280px minmax(0,1fr);gap:18px;align-items:start}.dict-type-list{list-style:none;margin:0;padding:8px;display:grid;gap:2px}.dict-type-item{cursor:pointer;padding:10px 12px;border-radius:8px;border:1px solid transparent}.dict-type-item:hover{background:#f1f5f9}.dict-type-item.active{background:#eff6ff;border-color:#93c5fd}.dict-type-main{display:grid;gap:2px}.dict-type-name{font-weight:700;font-size:13px;color:#0f172a}.dict-type-code{font-size:11px;color:#5d6b82}.switch{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-size:12px}.switch input{margin:0}@media (max-width: 880px){.dict-shell{grid-template-columns:1fr}}@media (max-width: 880px){.shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto;flex-direction:row;overflow-x:auto}.sidebar-brand{border-bottom:0;border-right:1px solid rgba(255,255,255,.07);flex-shrink:0}.sidebar-menu{display:flex;gap:4px}.menu-item{flex-shrink:0;width:auto}.sidebar-footer{display:none}}
