:root{--sidebar-width: 248px;--primary: #25a66a;--primary-dark: #15834f;--primary-soft: #eafaf1;--teal: #0ea5a3;--bg: #f6f8fb;--panel: #ffffff;--text: #102033;--text-soft: #667085;--text-muted: #98a2b3;--border: #e5eaf0;--border-soft: #eef2f6;--focus: 0 0 0 4px rgba(37, 166, 106, .14);--shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--shadow-sm: 0 8px 26px rgba(15, 23, 42, .07);--shadow-md: 0 14px 34px rgba(15, 23, 42, .1);--radius-sm: 8px;--radius: 12px;--radius-lg: 14px;--motion: .18s cubic-bezier(.4, 0, .2, 1);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:var(--bg)}*{box-sizing:border-box}body{min-width:1280px;min-height:100vh;margin:0;background:#f6f8fb;-webkit-font-smoothing:antialiased}button,input,select,textarea{font:inherit}button{border:0}#app{min-height:100vh}.card{border:1px solid var(--border);border-radius:var(--radius-lg);background:#fff;box-shadow:var(--shadow-xs);transition:transform var(--motion),box-shadow var(--motion),border-color var(--motion)}.module-card-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-bottom:14px;margin-bottom:16px;border-bottom:1px solid var(--border)}.module-card-title{margin:0;color:#0f172a;font-size:18px;font-weight:800;letter-spacing:-.2px}.card:hover{border-color:#dbe3ec;box-shadow:var(--shadow-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:38px;padding:0 15px;border-radius:12px;cursor:pointer;font-size:13px;font-weight:750;transition:transform var(--motion),box-shadow var(--motion),background var(--motion),border-color var(--motion),color var(--motion)}.btn:active{transform:scale(.985)}.btn:hover{transform:translateY(-1px)}.btn:focus-visible{outline:none;box-shadow:var(--focus)}.btn-primary{color:#fff;background:linear-gradient(135deg,var(--primary),#1f9e93);box-shadow:0 9px 18px #25a66a2e}.btn-primary:hover{box-shadow:0 12px 28px #25a66a3d}.btn-outline{border:1px solid var(--border);color:#475569;background:#fff}.btn-outline:hover{border-color:#cbd5e1;background:#f8fafc}.btn-ghost{color:#64748b;background:transparent}.btn-ghost:hover{background:#f1f5f9}.btn-danger{color:#dc2626;background:#fff7f7}.btn-sm{min-height:32px;padding:0 11px;border-radius:10px;font-size:12px}.icon-btn{width:38px;min-width:38px;height:38px;padding:0;border-radius:12px}.form-input,.form-select,.form-textarea{width:100%;border:1px solid var(--border);border-radius:12px;color:#334155;background:#fbfdff;transition:border-color var(--motion),box-shadow var(--motion),background var(--motion)}.form-input,.form-select{height:40px;padding:0 12px;line-height:40px}.form-textarea{min-height:96px;padding:10px 12px;resize:vertical}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:var(--focus)}.tag{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:0 9px;border-radius:999px;font-size:11.5px;font-weight:800;line-height:1;white-space:nowrap;word-break:keep-all}.tag-green{color:#059669;background:#ecfdf5}.tag-red{color:#dc2626;background:#fef2f2}.tag-yellow{color:#d97706;background:#fffbeb}.tag-blue{color:#2563eb;background:#eff6ff}.tag-purple{color:#7c3aed;background:#f5f3ff}.tag-slate{color:#475569;background:#f1f5f9}.table-wrap{position:relative;overflow:auto;border-radius:var(--radius);border:1px solid #eef2f6}.list-loading-shell{position:relative;overflow:hidden}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{padding:13px 12px;border-bottom:1px solid var(--border);color:#475569;background:#f8fafc;font-size:12px;font-weight:800;letter-spacing:0;text-align:left;white-space:nowrap}.data-table td{padding:14px 12px;border-bottom:1px solid #eef2f6;color:#344054;vertical-align:middle}.data-table tbody tr{transition:background var(--motion)}.data-table tbody tr:hover td{background:#fbfdfb}.stable-table-body{opacity:1;transform:translateY(0);transition:opacity .18s ease,transform .18s ease}.table-refreshing .stable-table-body{opacity:.58;transform:translateY(2px)}.ellipsis{display:inline-block;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:32px;background:#0f172a70;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fade-in .2s ease}.modal-panel{display:flex;flex-direction:column;width:min(920px,calc(100vw - 96px));max-height:calc(100vh - 64px);overflow:hidden;border:1px solid rgba(255,255,255,.72);border-radius:22px;background:#fff;box-shadow:0 28px 80px #02061740;animation:modal-pop .24s cubic-bezier(.4,0,.2,1)}.modal-header,.modal-footer{display:flex;align-items:center;justify-content:space-between;padding:18px 22px}.modal-header{flex:0 0 auto;border-bottom:1px solid #eef2f6}.modal-footer{flex:0 0 auto;justify-content:flex-end;gap:10px;border-top:1px solid #eef2f6}.modal-body{min-height:0;overflow:auto;padding:20px 22px}.modal-header h3{margin:0;color:#0f172a;font-size:18px;font-weight:850;letter-spacing:0}.modal-header p{margin:4px 0 0;color:#94a3b8;font-size:12px;font-weight:650}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-field{display:grid;gap:6px}.form-field-full{grid-column:1 / -1}.form-label{color:#64748b;font-size:12px;font-weight:700}.form-label em{color:#ef4444;font-style:normal;font-weight:850}.toast{position:fixed;top:18px;left:50%;z-index:800;display:flex;align-items:center;gap:8px;min-height:42px;max-width:min(560px,calc(100vw - 32px));padding:10px 18px;border:1px solid rgba(203,213,225,.72);border-radius:999px;color:#475569;background:#f8fafcf5;box-shadow:0 14px 34px #0f172a1f;transform:translate(-50%);font-size:13px;font-weight:700;line-height:1.45;text-align:center;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.toast-success{border-color:#bbf7d0e6;color:#166534;background:#ecfdf5f5}.toast-error{border-color:#fecacaeb;color:#b42318;background:#fef2f2f5}.toast-info{border-color:#bfdbfed6;color:#1d4ed8;background:#eff6fff5}.empty-state{padding:42px 16px;color:#94a3b8;text-align:center}.loading-overlay{position:absolute;top:10px;right:12px;z-index:6;display:flex;align-items:center;justify-content:center;min-height:28px;padding:0 12px;border:1px solid rgba(187,247,208,.9);border-radius:999px;color:#64748b;background:#ffffffeb;box-shadow:0 10px 24px #0f172a14;font-size:12px;font-weight:800;pointer-events:none}.loading-overlay:before{width:14px;height:14px;margin-right:8px;border:2px solid rgba(37,166,106,.2);border-top-color:var(--primary);border-radius:999px;content:"";animation:spin .72s linear infinite}.list-row-enter-active,.list-row-leave-active,.list-card-enter-active,.list-card-leave-active,.message-row-enter-active,.message-row-leave-active{transition:opacity .2s ease,transform .2s ease}.list-row-enter-from,.list-row-leave-to{opacity:0;transform:translateY(8px)}.list-card-enter-from,.list-card-leave-to,.message-row-enter-from,.message-row-leave-to{opacity:0;transform:translateY(10px) scale(.985)}.list-row-move,.list-card-move,.message-row-move{transition:transform .2s ease}.table-skeleton-row td{height:56px;background:#fff}.skeleton-line,.skeleton-pill,.skeleton-avatar{position:relative;display:block;overflow:hidden;background:linear-gradient(90deg,#eef3f7,#f8fbfd 48%,#eef3f7);background-size:220% 100%;animation:skeleton-shimmer 1.15s ease-in-out infinite}.skeleton-line{width:82%;height:12px;border-radius:999px}.skeleton-line.short{width:42%}.skeleton-line.medium{width:62%}.skeleton-pill{width:54px;height:24px;border-radius:999px}.skeleton-avatar{width:38px;height:38px;border-radius:12px}.fade-slide-enter-active,.fade-slide-leave-active{transition:opacity var(--motion),transform var(--motion)}.fade-slide-enter-from,.fade-slide-leave-to{opacity:0;transform:translateY(8px)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-pop{0%{opacity:0;transform:scale(.95) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.toast-slide-enter-active,.toast-slide-leave-active{transition:opacity var(--motion),transform var(--motion)}.toast-slide-enter-from,.toast-slide-leave-to{opacity:0;transform:translate(-50%) translateY(-10px)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes skeleton-shimmer{0%{background-position:120% 0}to{background-position:-120% 0}}
