.fade-enter-active[data-v-17899eb7],.fade-leave-active[data-v-17899eb7]{transition:opacity .2s,transform .2s}.fade-enter-from[data-v-17899eb7],.fade-leave-to[data-v-17899eb7]{opacity:0;transform:translate(-50%,10px)}:root{--accent: #4f46e5;--accent-hover: #4338ca;--accent-soft: #eef2ff;--bg: #f5f6fa;--card: #ffffff;--text: #1f2430;--text-soft: #6b7280;--border: #e5e7eb;--danger: #dc2626;--danger-soft: #fef2f2;--success: #16a34a;--warn: #d97706;--radius: 12px;--shadow: 0 1px 3px rgba(16, 24, 40, .06), 0 8px 24px rgba(16, 24, 40, .06)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.navbar{background:var(--card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.navbar-inner{max-width:1080px;margin:0 auto;padding:0 20px;height:56px;display:flex;align-items:center;gap:18px}.brand{font-weight:700;font-size:17px;color:var(--text);white-space:nowrap}.brand:hover{text-decoration:none}.nav-links{display:flex;align-items:center;gap:6px;margin-left:auto;flex-wrap:wrap}.nav-links a,.nav-links button{padding:7px 12px;border-radius:8px;color:var(--text-soft);font-size:14px;border:none;background:none;cursor:pointer;font:inherit}.nav-links a.router-link-active{color:var(--accent);background:var(--accent-soft);text-decoration:none}.nav-links a:hover,.nav-links button:hover{background:var(--bg);text-decoration:none}.page{max-width:1080px;margin:0 auto;padding:24px 20px 64px}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:380px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:32px 28px}.auth-card h1{margin:0 0 4px;font-size:22px}.auth-sub{color:var(--text-soft);margin:0 0 22px;font-size:14px}.auth-foot{margin-top:18px;font-size:14px;color:var(--text-soft);text-align:center}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;margin-bottom:20px}.card h2{margin:0 0 16px;font-size:17px}.card h3{margin:0 0 12px;font-size:15px}.card-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.card-row:last-child{border-bottom:none}.card-row .label{color:var(--text-soft);font-size:14px}.card-row .value{font-weight:600;word-break:break-all;text-align:right}.field{margin-bottom:14px}.field label{display:block;font-size:13px;color:var(--text-soft);margin-bottom:6px;font-weight:500}.field .hint{font-size:12px;color:var(--text-soft);margin-top:4px;font-weight:400}input,select,textarea{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:8px;font:inherit;font-size:14px;background:#fff;color:var(--text);transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}textarea{resize:vertical;min-height:92px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px}input[readonly]{background:var(--bg);color:var(--text-soft)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 16px;border-radius:8px;border:1px solid transparent;background:var(--accent);color:#fff;font:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s;white-space:nowrap}.btn:hover{background:var(--accent-hover)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-block{width:100%}.btn-ghost{background:#fff;border-color:var(--border);color:var(--text)}.btn-ghost:hover{background:var(--bg)}.btn-danger{background:var(--danger)}.btn-danger:hover{background:#b91c1c}.btn-sm{padding:5px 10px;font-size:13px;font-weight:500}.btn-row{display:flex;gap:8px;flex-wrap:wrap}.copy-box{display:flex;gap:8px;align-items:stretch}.copy-box input{flex:1}.progress{height:10px;width:100%;background:var(--border);border-radius:999px;overflow:hidden}.progress>span{display:block;height:100%;background:var(--accent);border-radius:999px;transition:width .3s ease}.progress.warn>span{background:var(--warn)}.progress.danger>span{background:var(--danger)}.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.6}.badge.ok{background:#dcfce7;color:#166534}.badge.off{background:#fee2e2;color:#991b1b}.badge.muted{background:var(--bg);color:var(--text-soft)}.badge.admin{background:var(--accent-soft);color:var(--accent)}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;font-size:14px}th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap}th{color:var(--text-soft);font-weight:600;font-size:13px;background:var(--bg)}tbody tr:hover{background:#fafbff}td .btn-row{flex-wrap:nowrap}.tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border);flex-wrap:wrap}.tab{padding:10px 16px;cursor:pointer;border:none;background:none;font:inherit;font-size:15px;color:var(--text-soft);border-bottom:2px solid transparent;margin-bottom:-1px}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.alert{padding:10px 14px;border-radius:8px;font-size:14px;margin-bottom:14px}.alert.error{background:var(--danger-soft);color:var(--danger);border:1px solid #fecaca}.alert.success{background:#f0fdf4;color:var(--success);border:1px solid #bbf7d0}.muted{color:var(--text-soft)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:12px;flex-wrap:wrap}.section-head h2{margin:0}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#1f2430;color:#fff;padding:10px 18px;border-radius:999px;font-size:14px;box-shadow:var(--shadow);z-index:100}.switch-row{display:flex;align-items:center;gap:10px}.switch-row input[type=checkbox]{width:auto}.spacer{flex:1}@media(max-width:640px){.grid-2{grid-template-columns:1fr}.card{padding:18px 16px}}
