*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;background:var(--color-bg, #f0f4f0);color:var(--color-text, #3a4a3e);min-height:100vh}.global-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:12px;color:var(--color-text-sub, #6e8070)}.spinner{width:36px;height:36px;border:3px solid var(--color-border, #d8e8dc);border-top-color:var(--color-primary, #4a9b6f);border-radius:50%;animation:spin .8s linear infinite}::-webkit-scrollbar-track{background:var(--color-bg, #f0f4f0)}::-webkit-scrollbar-thumb{background:#b8ccbe;border-radius:3px}.btn-primary{background:var(--color-primary, #4a9b6f);color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:15px;cursor:pointer;transition:background .2s}.btn-primary:hover{background:var(--color-primary-hover, #3a8a5e)}.btn-primary:disabled{background:#a0c8b0;cursor:not-allowed}.btn-secondary{background:var(--color-bg-card, #fafcfa);color:var(--color-text, #3a4a3e);border:1px solid var(--color-border, #d8e8dc);border-radius:8px;padding:10px 20px;font-size:15px;cursor:pointer;transition:all .2s}.btn-secondary:hover{border-color:var(--color-primary, #4a9b6f);color:var(--color-primary, #4a9b6f)}.btn-danger{background:#c0524e;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:14px;cursor:pointer}.btn-danger:hover{background:#a84442}.card{background:var(--color-bg-card, #fafcfa);border-radius:12px;padding:16px;box-shadow:0 1px 4px var(--color-shadow, rgba(60,80,60,.08));margin-bottom:12px;border:1px solid var(--color-border, #d8e8dc)}.tag-green{background:#dff0e6;color:#357a52}.tag-red{background:#fde8e8;color:#c0524e}.tag-orange{background:#fdf0e0;color:#c87d2e}.tag-blue{background:#e0edf8;color:#3a72b0}.tag-gray{background:#eef2ee;color:var(--color-text-sub, #6e8070)}.form-group label{display:block;font-size:14px;color:var(--color-text-sub, #6e8070);margin-bottom:6px;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;border:1px solid var(--color-border, #d8e8dc);border-radius:8px;padding:10px 12px;font-size:15px;outline:none;transition:border-color .2s;background:var(--color-bg-card, #fafcfa);color:var(--color-text, #3a4a3e)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary, #4a9b6f);box-shadow:0 0 0 2px #4a9b6f26}.alert-warning{background:#fdf5e4;border:1px solid #f0d58c;color:#8c6020}.alert-danger{background:#fde8e8;border:1px solid #f0a8a4;color:#8c2020}.alert-success{background:#dff0e6;border:1px solid #90cc9c;color:#255a38}.alert-info{background:#e4eef8;border:1px solid #90b8e0;color:#20508c}.empty-state{text-align:center;padding:48px 24px;color:var(--color-text-sub, #6e8070)}.search-bar{display:flex;align-items:center;background:var(--color-bg-card, #fafcfa);border:1px solid var(--color-border, #d8e8dc);border-radius:8px;padding:0 12px;margin-bottom:12px}.search-bar input{border:none;outline:none;padding:10px 8px;flex:1;font-size:15px;background:transparent;color:var(--color-text, #3a4a3e)}.search-icon{color:var(--color-text-sub, #6e8070)}.divider{height:1px;background:var(--color-border, #d8e8dc);margin:12px 0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#283c2873;z-index:1000;display:flex;align-items:flex-end;justify-content:center}.modal-content{background:var(--color-bg-card, #fafcfa);border-radius:16px 16px 0 0;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;padding:20px;animation:slideUp .3s ease}.modal-close{background:none;border:none;font-size:22px;color:var(--color-text-sub, #6e8070);cursor:pointer;padding:0 4px}.toast{background:#283c28d1;color:#fff;padding:10px 20px;border-radius:20px;font-size:14px;animation:fadeInDown .3s ease,fadeOut .3s ease 2.7s forwards;white-space:nowrap}.toast.success{background:var(--color-primary, #4a9b6f)}.toast.error{background:#c0524e}.toast.warning{background:#c87d2e}.tab-bar{position:fixed;bottom:0;left:0;right:0;background:var(--color-bg-card, #fafcfa);border-top:1px solid var(--color-border, #d8e8dc);display:flex;z-index:100;padding-bottom:env(safe-area-inset-bottom,0px)}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:8px 0;font-size:10px;color:var(--color-text-sub, #6e8070);cursor:pointer;text-decoration:none;transition:color .2s}.tab-item.active{color:var(--color-primary, #4a9b6f)}.top-bar{background:var(--color-bg-card, #fafcfa);border-bottom:1px solid var(--color-border, #d8e8dc);padding:12px 16px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:99}.top-bar h1{font-size:17px;font-weight:600;flex:1;color:var(--color-text, #3a4a3e)}.back-btn{background:none;border:none;font-size:22px;cursor:pointer;color:var(--color-text, #3a4a3e);padding:0}.page-content{padding:12px 16px 72px;min-height:calc(100vh - 56px);background:var(--color-bg, #f0f4f0)}th{background:var(--color-primary-light, #e8f5ee);padding:10px 12px;text-align:left;font-weight:600;color:var(--color-text-sub, #6e8070);border-bottom:1px solid var(--color-border, #d8e8dc);white-space:nowrap}td{padding:10px 12px;border-bottom:1px solid var(--color-border, #d8e8dc);vertical-align:middle;color:var(--color-text, #3a4a3e)}tr:hover td{background:var(--color-primary-light, #e8f5ee)}.stat-card{background:var(--color-bg-card, #fafcfa);border-radius:12px;padding:16px;box-shadow:0 1px 4px var(--color-shadow, rgba(60,80,60,.08));text-align:center;border:1px solid var(--color-border, #d8e8dc)}.stat-card .stat-num{font-size:28px;font-weight:700;color:var(--color-primary, #4a9b6f);line-height:1.2}.stat-card .stat-label{font-size:12px;color:var(--color-text-sub, #6e8070);margin-top:4px}.list-item{background:var(--color-bg-card, #fafcfa);border-radius:10px;padding:14px 16px;margin-bottom:8px;box-shadow:0 1px 3px var(--color-shadow, rgba(60,80,60,.06));display:flex;align-items:center;gap:12px;cursor:pointer;transition:box-shadow .2s;border:1px solid var(--color-border, #d8e8dc)}.list-item:hover{box-shadow:0 2px 8px #3c503c24}.list-item-avatar{width:44px;height:44px;border-radius:50%;background:var(--color-primary-light, #e8f5ee);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.list-item-title{font-size:15px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--color-text, #3a4a3e)}.list-item-sub{font-size:13px;color:var(--color-text-sub, #6e8070);margin-top:2px}.section-title{font-size:14px;font-weight:600;color:var(--color-text-sub, #6e8070);letter-spacing:.5px;margin:16px 0 8px}.chip{padding:6px 14px;border-radius:20px;border:1px solid var(--color-border, #d8e8dc);background:var(--color-bg-card, #fafcfa);font-size:13px;cursor:pointer;transition:all .2s;color:var(--color-text, #3a4a3e)}.chip.active{background:var(--color-primary, #4a9b6f);border-color:var(--color-primary, #4a9b6f);color:#fff}.progress-bar{height:6px;background:var(--color-border, #d8e8dc);border-radius:3px;overflow:hidden}.skeleton{background:linear-gradient(90deg,var(--color-bg) 25%,var(--color-border) 50%,var(--color-bg) 75%);background-size:200% 100%;animation:shimmer 1.2s infinite;border-radius:6px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.global-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:12px;color:#666}.spinner{width:36px;height:36px;border:3px solid #e0e0e0;border-top-color:#07c160;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.btn-primary{background:#07c160;color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:15px;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#06ad56}.btn-primary:disabled{background:#a0d9b4;cursor:not-allowed}.btn-secondary{background:#fff;color:#333;border:1px solid #ddd;border-radius:8px;padding:10px 20px;font-size:15px;cursor:pointer;transition:all .2s}.btn-secondary:hover{border-color:#07c160;color:#07c160}.btn-danger{background:#ff4d4f;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:14px;cursor:pointer}.btn-danger:hover{background:#e84040}.card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 1px 4px #00000014;margin-bottom:12px}.tag{display:inline-block;padding:2px 10px;border-radius:20px;font-size:12px;font-weight:500}.tag-green{background:#e6f7ec;color:#07c160}.tag-red{background:#fff1f0;color:#ff4d4f}.tag-orange{background:#fff7e6;color:#fa8c16}.tag-blue{background:#e6f0ff;color:#1677ff}.tag-gray{background:#f5f5f5;color:#666}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:14px;color:#666;margin-bottom:6px;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;border:1px solid #ddd;border-radius:8px;padding:10px 12px;font-size:15px;outline:none;transition:border-color .2s;background:#fff}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#07c160;box-shadow:0 0 0 2px #07c1601f}.form-group textarea{resize:vertical;min-height:80px}.alert{padding:12px 16px;border-radius:8px;margin-bottom:12px;font-size:14px;display:flex;align-items:flex-start;gap:8px}.alert-warning{background:#fffbe6;border:1px solid #ffe58f;color:#ad6800}.alert-danger{background:#fff1f0;border:1px solid #ffa39e;color:#a8071a}.alert-success{background:#e6f7ec;border:1px solid #95de64;color:#135200}.alert-info{background:#e6f4ff;border:1px solid #91caff;color:#003eb3}.empty-state{text-align:center;padding:48px 24px;color:#999}.empty-state .empty-icon{font-size:48px;margin-bottom:12px}.empty-state p{font-size:15px}.search-bar{display:flex;align-items:center;background:#fff;border:1px solid #ddd;border-radius:8px;padding:0 12px;margin-bottom:12px}.search-bar input{border:none;outline:none;padding:10px 8px;flex:1;font-size:15px}.search-icon{color:#999}.divider{height:1px;background:#f0f0f0;margin:12px 0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:flex-end;justify-content:center}.modal-content{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;padding:20px;animation:slideUp .3s ease}.modal-content.center{border-radius:16px;margin:20px;max-height:80vh}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-header h3{font-size:17px;font-weight:600}.modal-close{background:none;border:none;font-size:22px;color:#999;cursor:pointer;padding:0 4px}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.2s infinite;border-radius:6px}@keyframes shimmer{to{background-position:-200% 0}}.toast-container{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:9999;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:8px}.toast{background:#000000bf;color:#fff;padding:10px 20px;border-radius:20px;font-size:14px;animation:fadeInDown .3s ease,fadeOut .3s ease 2.7s forwards;white-space:nowrap}.toast.success{background:#07c160}.toast.error{background:#ff4d4f}.toast.warning{background:#fa8c16}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{to{opacity:0}}.tab-bar{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #eee;display:flex;z-index:100;padding-bottom:env(safe-area-inset-bottom,0px)}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:8px 0;font-size:10px;color:#999;cursor:pointer;text-decoration:none;transition:color .2s}.tab-item.active{color:#07c160}.tab-icon{font-size:22px;margin-bottom:2px}.top-bar{background:#fff;border-bottom:1px solid #eee;padding:12px 16px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:99}.top-bar h1{font-size:17px;font-weight:600;flex:1}.back-btn{background:none;border:none;font-size:22px;cursor:pointer;color:#333;padding:0}.page-content{padding:12px 16px 72px;min-height:calc(100vh - 56px)}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;font-size:13px;min-width:500px}th{background:#fafafa;padding:10px 12px;text-align:left;font-weight:600;color:#666;border-bottom:1px solid #eee;white-space:nowrap}td{padding:10px 12px;border-bottom:1px solid #f0f0f0;vertical-align:middle}tr:hover td{background:#fafafa}.stat-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.stat-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 1px 4px #00000014;text-align:center}.stat-card .stat-num{font-size:28px;font-weight:700;color:#07c160;line-height:1.2}.stat-card .stat-label{font-size:12px;color:#999;margin-top:4px}.list-item{background:#fff;border-radius:10px;padding:14px 16px;margin-bottom:8px;box-shadow:0 1px 3px #0000000f;display:flex;align-items:center;gap:12px;cursor:pointer;transition:box-shadow .2s}.list-item:hover{box-shadow:0 2px 8px #0000001f}.list-item-avatar{width:44px;height:44px;border-radius:50%;background:#e6f7ec;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.list-item-info{flex:1;min-width:0}.list-item-title{font-size:15px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-item-sub{font-size:13px;color:#999;margin-top:2px}.list-item-right{text-align:right;flex-shrink:0}.section-title{font-size:14px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px;margin:16px 0 8px}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.chip{padding:6px 14px;border-radius:20px;border:1px solid #ddd;background:#fff;font-size:13px;cursor:pointer;transition:all .2s}.chip.active{background:#07c160;border-color:#07c160;color:#fff}.progress-bar{height:6px;background:#f0f0f0;border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .3s}:root{--color-bg: #f0f4f0;--color-bg-card: #fafcfa;--color-primary: #4a9b6f;--color-primary-light: #e8f5ee;--color-primary-hover: #3a8a5e;--color-text: #3a4a3e;--color-text-sub: #6e8070;--color-border: #d8e8dc;--color-warning: #c87d2e;--color-danger: #c0524e;--color-shadow: rgba(60,80,60,.08);color-scheme:light;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-bg)}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--color-bg);color:var(--color-text)}#root{width:100%;margin:0 auto}a{color:var(--color-primary);text-decoration:inherit}button{font-family:inherit;cursor:pointer}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}
