:root{--bg: #0b1f3a;--bg-grad: radial-gradient(1200px 600px at 80% -10%, #16335c 0%, #0b1f3a 55%);--card: #ffffff;--ink: #1a2433;--muted: #6b7a90;--line: #e6ebf2;--brand: #f6a821;--brand-2: #1f9d57;--accent: #2f6fed;--shadow: 0 6px 24px rgba(11, 31, 58, .08);--radius: 16px}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{font-family:Noto Sans TC,-apple-system,Segoe UI,Roboto,PingFang TC,Microsoft JhengHei,sans-serif;color:var(--ink);background:var(--bg-grad) fixed,var(--bg);-webkit-font-smoothing:antialiased}.app{max-width:1180px;margin:0 auto;padding:calc(20px + env(safe-area-inset-top)) calc(16px + env(safe-area-inset-right)) 56px calc(16px + env(safe-area-inset-left))}.header{display:flex;align-items:center;gap:12px;color:#fff;padding:8px 4px 18px;flex-wrap:wrap}.header .logo{width:38px;height:38px;display:grid;place-items:center;background:var(--brand);border-radius:11px;font-size:20px;box-shadow:var(--shadow)}.header h1{font-size:20px;margin:0;font-weight:800;letter-spacing:.5px}.header .sub{color:#aebfd6;font-size:13px;margin-top:2px}.header .spacer{flex:1}.controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}.select,.btn{font:inherit;border:1px solid rgba(255,255,255,.15);background:#ffffff14;color:#fff;padding:9px 14px;border-radius:11px;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.select{min-width:200px}.select option{color:#1a2433}.btn:hover{background:#ffffff29}.btn-primary{background:var(--brand);border-color:var(--brand);color:#2a1a00;font-weight:700}.btn-primary:hover{filter:brightness(1.05)}.btn:disabled{opacity:.5;cursor:not-allowed}.tabs{display:inline-flex;background:#ffffff14;border-radius:12px;padding:4px;gap:2px}.tab{border:none;background:transparent;color:#cdd9ec;padding:8px 16px;border-radius:9px;cursor:pointer;font:inherit;font-weight:600}.tab.active{background:#fff;color:var(--ink);box-shadow:var(--shadow)}.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:16px 0}.card{background:var(--card);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}.card .k{color:var(--muted);font-size:13px;display:flex;align-items:center;gap:6px}.card .v{font-size:26px;font-weight:800;margin-top:6px}.card .u{font-size:13px;color:var(--muted);font-weight:600;margin-left:4px}.card .v.brand{color:var(--brand)}.card .v.green{color:var(--brand-2)}.panel{background:var(--card);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.panel-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;flex-wrap:wrap;gap:8px}.panel-title h2{font-size:16px;margin:0}.panel-title .meta{color:var(--muted);font-size:13px}.logwrap{overflow-x:auto}.logtable{width:100%;border-collapse:collapse;font-size:14px}.logtable th{text-align:left;color:var(--muted);font-weight:600;padding:8px 10px;border-bottom:1px solid var(--line);white-space:nowrap}.logtable td{padding:10px;border-bottom:1px solid #f1f4f8;vertical-align:top}.logtable tr:last-child td{border-bottom:none}.logtable .mono{font-variant-numeric:tabular-nums;color:var(--muted)}.logtime{white-space:nowrap}.logtime .t{color:var(--muted)}.col-time{width:152px}.col-type{width:90px}.col-plant{width:130px}.msg{word-break:break-word}.badge{display:inline-block;font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap}.badge-critical{background:#fdecec;color:#b3261e}.badge-warning{background:#fff3e0;color:#b26a00}@media (max-width: 600px){.logwrap{overflow-x:visible}.logtable{table-layout:fixed;font-size:13px}.logtable th,.logtable td{padding:8px 6px}.col-time{width:76px}.col-type{width:58px}.col-plant{width:82px}.logtime{white-space:normal;line-height:1.35}.logtime .d,.logtime .t{display:block}.badge{font-size:11px;padding:2px 7px}.logtable td.msg,.logtable td:nth-child(3){white-space:normal;word-break:break-word}}.state{color:#cdd9ec;text-align:center;padding:60px 0}.error{background:#fdecec;color:#b3261e;border-radius:12px;padding:12px 16px;margin:12px 0}.footer{color:#8ea4c4;font-size:12px;text-align:center;margin-top:28px}@media (max-width: 820px){.cards{grid-template-columns:repeat(2,1fr)}.header h1{font-size:18px}.select{min-width:150px;flex:1}}@media (max-width: 480px){.tab{padding:8px 11px}}
