*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,PingFang SC,Microsoft YaHei,sans-serif;background:#f0f2f5;color:#1a1a2e;font-size:14px;line-height:1.5}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0d3b26,#1a6b3c,#27ae60);position:relative;overflow:hidden}.login-wrap:before{content:"";position:absolute;width:600px;height:600px;background:#ffffff0a;border-radius:50%;top:-200px;right:-200px}.login-wrap:after{content:"";position:absolute;width:400px;height:400px;background:#ffffff0a;border-radius:50%;bottom:-100px;left:-100px}.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:#0f1923;display:flex;flex-direction:column;flex-shrink:0;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}.logo{display:flex;align-items:center;gap:12px;padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.06)}.logo-icon{font-size:36px}.logo-name{font-size:20px;font-weight:800;color:#fff;letter-spacing:1px}.logo-sub{font-size:11px;color:#4ade80;margin-top:2px;letter-spacing:2px}.nav-section{padding:16px 0 4px}.nav-label{font-size:11px;color:#4a5568;padding:0 20px 6px;letter-spacing:1px;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;color:#8892a4;text-decoration:none;font-size:14px;transition:all .15s;position:relative;border-radius:0}.nav-item:hover{color:#fff;background:#ffffff0d}.nav-item.router-link-active{color:#fff;background:linear-gradient(90deg,rgba(39,174,96,.25),transparent);border-left:3px solid #27ae60}.nav-icon{font-size:16px;width:20px;text-align:center}.nav-badge{margin-left:auto;background:#e74c3c;color:#fff;font-size:11px;padding:1px 7px;border-radius:999px;font-weight:700}.sidebar-user{margin-top:auto;display:flex;align-items:center;gap:10px;padding:16px 20px;border-top:1px solid rgba(255,255,255,.06)}.user-avatar{width:36px;height:36px;background:linear-gradient(135deg,#27ae60,#2ecc71);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:13px;color:#fff;font-weight:600}.user-role{font-size:11px;color:#4a5568}.logout-btn{font-size:18px;color:#4a5568;cursor:pointer;transition:color .15s}.logout-btn:hover{color:#e74c3c}.main-wrap{margin-left:240px;flex:1;display:flex;flex-direction:column;min-height:100vh}.topbar{height:56px;background:#fff;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:50;box-shadow:0 1px 4px #0000000f}.topbar-title{font-size:16px;font-weight:700;color:#1a1a2e}.topbar-right{display:flex;align-items:center;gap:16px}.topbar-time{font-size:13px;color:#999}.main{padding:24px 28px;flex:1}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-title{font-size:20px;font-weight:700;color:#1a1a2e}.card{background:#fff;border-radius:12px;padding:20px 24px;margin-bottom:20px;box-shadow:0 1px 4px #0000000f;border:1px solid #f0f0f0}.btn{padding:8px 18px;border-radius:8px;border:none;cursor:pointer;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex;align-items:center;gap:5px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#27ae60;color:#fff}.btn-primary:hover:not(:disabled){background:#219a52}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover:not(:disabled){background:#c0392b}.btn-warn{background:#f39c12;color:#fff}.btn-warn:hover:not(:disabled){background:#d68910}.btn-blue{background:#2980b9;color:#fff}.btn-blue:hover:not(:disabled){background:#2471a3}.btn-gray{background:#f0f0f0;color:#555}.btn-gray:hover:not(:disabled){background:#e0e0e0}.btn-sm{padding:5px 12px;font-size:12px;border-radius:6px}.btn-outline{background:transparent;border:1px solid #27ae60;color:#27ae60}.btn-outline:hover{background:#27ae60;color:#fff}.input{width:100%;padding:8px 12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;outline:none;transition:border-color .15s;background:#fff}.input:focus{border-color:#27ae60;box-shadow:0 0 0 3px #27ae601a}.select{padding:8px 12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;outline:none;background:#fff;cursor:pointer}.select:focus{border-color:#27ae60}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{padding:10px 14px;text-align:left;background:#f8fafb;font-size:12px;font-weight:600;color:#666;border-bottom:1px solid #eee;white-space:nowrap}td{padding:12px 14px;border-bottom:1px solid #f5f5f5;font-size:13px;color:#333}tr:last-child td{border-bottom:none}tr:hover td{background:#fafffe}.tag{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:500;white-space:nowrap}.tag-green{background:#eafaf1;color:#1e8449}.tag-orange{background:#fef9e7;color:#d68910}.tag-red{background:#fdedec;color:#c0392b}.tag-gray{background:#f2f2f2;color:#777}.tag-blue{background:#eaf4fd;color:#2471a3}.tag-purple{background:#f5eef8;color:#7d3c98}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:#fff;border-radius:16px;padding:28px 32px;width:460px;max-width:95vw;box-shadow:0 20px 60px #0003;animation:modal-in .2s ease}@keyframes modal-in{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal-title{font-size:18px;font-weight:700;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid #f0f0f0}.modal-footer{display:flex;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid #f0f0f0}.form-row{margin-bottom:16px}.form-label{font-size:13px;color:#555;margin-bottom:6px;font-weight:500}.pagination{display:flex;gap:6px;align-items:center;margin-top:16px;justify-content:flex-end}.page-btn{padding:6px 12px;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;background:#fff;font-size:13px;transition:all .15s}.page-btn:hover:not(:disabled){border-color:#27ae60;color:#27ae60}.page-btn.active{background:#27ae60;color:#fff;border-color:#27ae60}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-info{font-size:13px;color:#999;margin-right:8px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.stat-card{background:#fff;border-radius:12px;padding:20px 24px;box-shadow:0 1px 4px #0000000f;border:1px solid #f0f0f0;position:relative;overflow:hidden}.stat-card:after{content:attr(data-icon);position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:40px;opacity:.08}.stat-num{font-size:30px;font-weight:800}.stat-label{font-size:13px;color:#999;margin-top:4px}.stat-trend{font-size:12px;margin-top:6px}.flex{display:flex;gap:10px;align-items:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.mt{margin-top:12px}.mt2{margin-top:20px}.text-green{color:#27ae60}.text-red{color:#e74c3c}.text-muted{color:#999}.fw700{font-weight:700}.ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty{text-align:center;padding:60px 0;color:#bbb}.empty-icon{font-size:48px;margin-bottom:12px}.login-box[data-v-88e51a4a]{display:flex;background:#fff;border-radius:20px;overflow:hidden;width:820px;max-width:95vw;box-shadow:0 24px 80px #00000040;position:relative;z-index:1}.login-brand[data-v-88e51a4a]{width:340px;background:linear-gradient(160deg,#0d3b26,#1a6b3c);padding:48px 36px;display:flex;flex-direction:column;justify-content:center;flex-shrink:0}.brand-icon[data-v-88e51a4a]{font-size:56px;margin-bottom:12px}.brand-name[data-v-88e51a4a]{font-size:36px;font-weight:800;color:#fff;letter-spacing:2px}.brand-slogan[data-v-88e51a4a]{font-size:14px;color:#ffffffa6;margin-top:8px;margin-bottom:36px}.feature-item[data-v-88e51a4a]{font-size:14px;color:#fffc;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.08)}.feature-item[data-v-88e51a4a]:last-child{border-bottom:none}.admin-only[data-v-88e51a4a]{color:#ffc800b3;font-size:12px;margin-top:4px}.login-form-wrap[data-v-88e51a4a]{flex:1;padding:48px 40px;display:flex;flex-direction:column;justify-content:center}.login-form-title[data-v-88e51a4a]{font-size:24px;font-weight:800;color:#1a1a2e}.login-form-sub[data-v-88e51a4a]{font-size:14px;color:#999;margin-top:6px}.login-btn[data-v-88e51a4a]{width:100%;padding:12px;font-size:15px;border-radius:10px;margin-top:8px;justify-content:center}.login-err[data-v-88e51a4a]{color:#e74c3c;font-size:13px;margin-bottom:10px;background:#fdedec;padding:8px 12px;border-radius:8px}.login-tip[data-v-88e51a4a]{font-size:12px;color:#bbb;text-align:center;margin-top:16px}.section-title[data-v-ddb76e47]{font-size:15px;font-weight:700;color:#333;margin:4px 0 14px}.alert-card[data-v-ddb76e47]:hover{box-shadow:0 4px 16px #0000001a}.perm-grid[data-v-6494a4e3]{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.perm-item[data-v-6494a4e3]{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:13px;transition:all .15s}.perm-item input[data-v-6494a4e3]{display:none}.perm-item.active[data-v-6494a4e3]{border-color:#27ae60;background:#eafaf1;color:#1e8449;font-weight:600}.perm-item[data-v-6494a4e3]:hover{border-color:#27ae60}.tab-bar[data-v-ea519265]{display:flex;gap:4px;margin-bottom:16px;background:#fff;border-radius:12px;padding:6px;box-shadow:0 1px 4px #0000000f}.tab-item[data-v-ea519265]{flex:1;text-align:center;padding:10px 0;border-radius:8px;cursor:pointer;font-size:14px;color:#666;transition:all .15s;position:relative}.tab-item[data-v-ea519265]:hover{background:#f5f5f5}.tab-item.active[data-v-ea519265]{background:#27ae60;color:#fff;font-weight:600}.tab-count[data-v-ea519265]{position:absolute;top:4px;right:8px;background:#e74c3c;color:#fff;font-size:11px;padding:1px 6px;border-radius:999px;font-weight:700}.action-btns[data-v-ea519265]{display:flex;gap:6px}.group-header[data-v-7b1fe4cb]{margin-bottom:20px}.group-title[data-v-7b1fe4cb]{font-size:16px;font-weight:700;color:#1a1a2e}.group-desc[data-v-7b1fe4cb]{font-size:13px;color:#999;margin-top:4px}.config-grid[data-v-7b1fe4cb]{display:grid;grid-template-columns:repeat(2,1fr);gap:16px 24px}.config-label[data-v-7b1fe4cb]{font-size:13px;font-weight:600;color:#444;margin-bottom:6px}.config-desc[data-v-7b1fe4cb]{font-size:12px;color:#bbb;font-weight:400;margin-left:6px}.bool-toggle[data-v-7b1fe4cb]{display:flex;gap:8px}.toggle-opt[data-v-7b1fe4cb]{flex:1;text-align:center;padding:8px;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:13px;transition:all .15s}.toggle-opt input[data-v-7b1fe4cb]{display:none}.toggle-opt.on[data-v-7b1fe4cb]{border-color:#27ae60;background:#eafaf1;color:#1e8449;font-weight:600}.toggle-opt.off[data-v-7b1fe4cb]{border-color:#e74c3c;background:#fdedec;color:#c0392b;font-weight:600}.secret-wrap[data-v-7b1fe4cb]{display:flex;gap:8px}.secret-wrap .input[data-v-7b1fe4cb]{flex:1}.group-footer[data-v-7b1fe4cb]{margin-top:20px;padding-top:16px;border-top:1px solid #f0f0f0;display:flex;align-items:center;gap:12px}.save-ok[data-v-7b1fe4cb]{color:#27ae60;font-size:13px;font-weight:600}.readonly-note[data-v-7b1fe4cb]{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:10px 14px;font-size:13px;color:#666;line-height:1.6}.plans-grid[data-v-92d2aec8]{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.plan-card[data-v-92d2aec8]{background:#fff;border-radius:14px;padding:24px;border:1px solid #f0f0f0;box-shadow:0 1px 4px #0000000f;transition:box-shadow .2s}.plan-card[data-v-92d2aec8]:hover{box-shadow:0 4px 16px #0000001a}.plan-card.inactive[data-v-92d2aec8]{opacity:.55}.plan-header[data-v-92d2aec8]{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.plan-title[data-v-92d2aec8]{font-size:18px;font-weight:700}.plan-price[data-v-92d2aec8]{display:flex;align-items:baseline;gap:8px;margin-bottom:6px}.price-num[data-v-92d2aec8]{font-size:32px;font-weight:800;color:#27ae60}.price-origin[data-v-92d2aec8]{font-size:14px;color:#bbb;text-decoration:line-through}.plan-duration[data-v-92d2aec8]{font-size:13px;color:#999;margin-bottom:8px}.plan-desc[data-v-92d2aec8]{font-size:13px;margin-bottom:16px;min-height:20px}.plan-actions[data-v-92d2aec8]{display:flex;gap:8px}.perm-item[data-v-92d2aec8]{border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:13px}.perm-item.active[data-v-92d2aec8]{border-color:#27ae60;background:#eafaf1;color:#1e8449;font-weight:600}.perm-item[data-v-2ba5834f]{border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:13px}.perm-item.active[data-v-2ba5834f]{border-color:#27ae60;background:#eafaf1;color:#1e8449;font-weight:600}
