:root{--font-sans: "Sarabun", system-ui, -apple-system, sans-serif;--bg: #F1F5F9;--navy: #1E3A8A;--blue: #1E40AF;--blue2: #2563EB;--blue-light: #DBEAFE;--text: #1E293B;--muted: #64748B;--faint: #94A3B8;--line: #E2E8F0;--line2: #CBD5E1;--field: #F8FAFC;--danger: #DC2626;--danger-soft: #FEE2E2;--warn: #92400E;--warn-soft: #FEF3C7;--green: #10B981;--green-soft: #D1FAE5;--amber: #D97706;--panel: #FFFFFF;--accent: #2563EB;--red: #DC2626}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:13px}a{color:inherit;text-decoration:none}code{font-size:11.5px;color:var(--blue);background:var(--blue-light);padding:1px 5px;border-radius:4px}.bare{min-height:100vh;display:grid;place-items:center}.shell{max-width:1440px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.header{background:var(--navy);color:#fff;padding:9px 14px;display:flex;align-items:center;gap:10px}.brand{font-weight:700;letter-spacing:.6px;font-size:13px;color:#fff}.brand span{background:linear-gradient(90deg,#93c5fd,#6ee7b7);-webkit-background-clip:text;background-clip:text;color:transparent}.nav-title{font-size:12px;opacity:.85;padding-left:10px;border-left:.5px solid rgba(255,255,255,.25)}.header-right{margin-left:auto;display:flex;align-items:center;gap:10px}.status-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 2px #10b9814d}.user-name{font-size:11.5px;font-weight:600;color:#fff;opacity:.92}.avatar{width:25px;height:25px;border-radius:50%;background:#93c5fd;color:var(--navy);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.logout{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:6px;border:0;background:#ffffff24;color:#fff;cursor:pointer;font-family:inherit;font-size:11px}.logout:hover{background:#ffffff40}.tabbar{background:var(--navy);padding:0 10px;display:flex;gap:2px;overflow-x:auto}.tabbar a{background:#ffffff14;color:#dbeafe;padding:7px 14px;font-size:12px;border-radius:7px 7px 0 0;margin-top:4px;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.tabbar a.router-link-active{background:var(--bg);color:var(--blue);font-weight:600}.content{padding:16px 18px 30px;flex:1}h1{font-size:17px;margin:0 0 3px;color:var(--text);font-weight:700}.sub{color:var(--muted);font-size:12px;margin-bottom:16px}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:18px}.card{background:#fff;border:.5px solid var(--line);border-radius:10px;padding:14px 16px}.card .k{color:var(--muted);font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.card .v{font-size:24px;font-weight:700;margin-top:5px}.card.c-blue{border-top:3px solid var(--blue2)}.card.c-green{border-top:3px solid var(--green)}.card.c-amber{border-top:3px solid var(--amber)}.card.c-red{border-top:3px solid var(--danger)}table{width:100%;border-collapse:collapse;font-size:12px;background:#fff;border:.5px solid var(--line);border-radius:10px;overflow:hidden}th,td{text-align:left;padding:9px 12px;border-bottom:.5px solid var(--line)}th{color:var(--muted);font-weight:600;font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;background:var(--field)}tbody tr:hover{background:var(--field)}.badge{font-size:11px;padding:2px 9px;border-radius:999px;font-weight:600}.badge.on{background:var(--green-soft);color:#047857}.badge.off{background:var(--danger-soft);color:var(--danger)}.badge.warn{background:var(--warn-soft);color:var(--warn)}.btn{background:var(--blue2);color:#fff;border:none;border-radius:7px;padding:8px 16px;font-weight:600;cursor:pointer;font-family:inherit;font-size:12px}.btn:hover{filter:brightness(1.08)}.btn:disabled{opacity:.55;cursor:default}.btn.ghost{background:#fff;color:var(--muted);border:.5px solid var(--line2)}.link{background:none;border:none;color:var(--blue2);cursor:pointer;padding:0 6px;font-size:12px;font-family:inherit}.field{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}.field input,.field select{background:#fff;border:.5px solid var(--line2);color:var(--text);border-radius:7px;padding:7px 10px;font-family:inherit;font-size:12px}.banner{background:var(--blue-light);color:var(--blue);border:.5px solid #BFDBFE;padding:10px 14px;border-radius:8px;margin-bottom:14px;font-size:12px}.err{color:var(--danger);font-size:12px}.install-card{background:#fff;border:.5px solid var(--line);border-radius:10px;padding:16px;margin-bottom:18px}.install-head{display:flex;justify-content:space-between;align-items:center}.cmd{display:flex;gap:10px;align-items:center;background:var(--field);border:.5px solid var(--line2);border-radius:8px;padding:10px 12px;margin-top:8px}.cmd code{font-size:11.5px;word-break:break-all;flex:1;background:none;padding:0}.login-card{background:#fff;border:.5px solid var(--line);border-radius:16px;padding:40px;text-align:center;max-width:380px;box-shadow:0 10px 40px #1e3a8a14}.drawer-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:40}.drawer{position:fixed;top:0;right:0;bottom:0;width:min(640px,94vw);background:#fff;z-index:50;box-shadow:-12px 0 40px #0f172a2e;display:flex;flex-direction:column}.drawer-head{background:var(--navy);color:#fff;padding:12px 16px;display:flex;align-items:center;gap:10px}.drawer-body{padding:16px;overflow-y:auto;flex:1}.kv{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-bottom:14px}.kv .item{background:var(--field);border:.5px solid var(--line);border-radius:8px;padding:8px 10px}.kv .item .k{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.kv .item .v{font-size:13px;font-weight:700;margin-top:2px}.transcript{background:var(--field);border:.5px solid var(--line);border-radius:8px;padding:12px;font-size:12px;line-height:1.7;max-height:320px;overflow-y:auto}.score-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:.5px solid var(--line);font-size:12px}.score-bar{height:7px;border-radius:99px;background:var(--line);flex:1;overflow:hidden}.score-bar>i{display:block;height:100%;border-radius:99px}.sec-title2{font-size:12px;font-weight:700;color:var(--blue);margin:14px 0 4px}
