:root{color:#1f2824;background:#f5f7f2;font-family:Inter,Segoe UI,Microsoft YaHei,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--surface: #ffffff;--surface-muted: #f8faf6;--border: #d8dfd8;--border-strong: #b8c3ba;--text-muted: #64706a;--accent: #147d64;--accent-strong: #0f6753;--accent-soft: #dff1eb;--amber: #a95f00;--amber-soft: #fff0d6;--red: #b42318;--red-soft: #ffe4df;--blue: #2563a9;--blue-soft: #e5effb;--shadow: 0 10px 30px rgba(24, 35, 29, .08)}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button{display:inline-flex;min-height:40px;align-items:center;justify-content:center;gap:8px;border:0;border-radius:6px;cursor:pointer;transition:background .16s ease,border-color .16s ease,color .16s ease,transform .16s ease}button:not(:disabled):active{transform:translateY(1px)}button:disabled{cursor:not-allowed;opacity:.55}input,select{width:100%;min-height:40px;padding:8px 10px;color:#17211d;background:#fff;border:1px solid var(--border);border-radius:6px;outline:none}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #147d6424}input:disabled,select:disabled{color:#7b8580;background:#eef2ef}.app-shell{width:min(1440px,100%);min-height:100vh;margin:0 auto;padding:24px}.app-heading{display:grid;grid-template-columns:minmax(260px,420px) 1fr;gap:20px;align-items:end;margin-bottom:18px}.heading-title{display:flex;align-items:center;gap:14px}.brand-mark{display:grid;width:48px;height:48px;flex:0 0 48px;place-items:center;color:#fff;background:linear-gradient(135deg,var(--accent),var(--blue));border-radius:12px;box-shadow:var(--shadow)}.app-heading h1,.panel h2{margin:0;letter-spacing:0}.app-heading h1{color:#17211d;font-size:30px;line-height:1.2}.panel h2{color:#17211d;font-size:18px;line-height:1.3}.eyebrow{margin:0 0 4px;color:var(--text-muted);font-size:12px;font-weight:700;letter-spacing:0}.top-status-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.top-status-grid div{min-width:0;padding:10px 12px;background:#ffffffb8;border:1px solid var(--border);border-radius:8px}.top-status-grid span,.top-status-grid strong{display:block;min-width:0;overflow-wrap:anywhere}.top-status-grid span{margin-bottom:4px;color:var(--text-muted);font-size:12px}.top-status-grid strong{color:#17211d;font-size:13px}.workspace-grid{display:grid;grid-template-columns:minmax(320px,430px) minmax(0,1fr);gap:16px;align-items:start}.left-column,.right-column{display:grid;gap:16px}.panel{min-width:0;padding:18px;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow)}.panel-header{display:flex;gap:12px;align-items:center;justify-content:space-between;margin-bottom:16px}.panel-header.compact{margin-bottom:12px}.status-pill{display:inline-flex;min-height:28px;max-width:100%;align-items:center;justify-content:center;gap:6px;padding:5px 10px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap}.status-pill.small{min-height:24px;padding:3px 8px}.connection-idle,.connection-disconnected{color:#5d6862;background:#edf1ec}.connection-connecting,.connection-reconnecting{color:var(--amber);background:var(--amber-soft)}.connection-connected{color:var(--accent-strong);background:var(--accent-soft)}.connection-error{color:var(--red);background:var(--red-soft)}.status-idle{color:#5d6862;background:#edf1ec}.status-running{color:var(--blue);background:var(--blue-soft)}.status-done{color:var(--accent-strong);background:var(--accent-soft)}.status-failed{color:var(--red);background:var(--red-soft)}.form-grid{display:grid;gap:12px}.form-grid.two-columns{grid-template-columns:repeat(2,minmax(0,1fr))}.span-two{grid-column:1 / -1}.field{display:grid;gap:6px;min-width:0}.field span{color:#3f4b45;font-size:13px;font-weight:700}.action-row{display:flex;gap:10px;align-items:center;margin-top:14px}.primary-button,.secondary-button,.ghost-button{padding:0 14px;font-weight:700}.button-symbol{display:inline-grid;min-width:22px;height:22px;padding:0 5px;place-items:center;border:1px solid currentColor;border-radius:5px;font-size:10px;font-weight:800;line-height:1}.primary-button{color:#fff;background:var(--accent)}.primary-button:not(:disabled):hover{background:var(--accent-strong)}.secondary-button{color:#25302b;background:#fff;border:1px solid var(--border-strong)}.secondary-button:not(:disabled):hover,.ghost-button:not(:disabled):hover{color:var(--accent-strong);border-color:var(--accent)}.ghost-button{min-height:34px;color:#3f4b45;background:transparent;border:1px solid transparent}.wide{width:100%}.inline-error,.inline-warning{margin:12px 0 0;padding:10px 12px;border-radius:6px;font-size:13px;line-height:1.5}.inline-error{color:var(--red);background:var(--red-soft)}.inline-warning{color:var(--amber);background:var(--amber-soft)}.meta-list,.detail-grid{display:grid;gap:10px;margin:14px 0 0}.meta-list.single{margin:0}.meta-list div,.detail-grid div{min-width:0}.meta-list dt,.detail-grid dt{margin-bottom:4px;color:var(--text-muted);font-size:12px;font-weight:700}.meta-list dd,.detail-grid dd{min-width:0;margin:0;color:#17211d;font-size:13px;overflow-wrap:anywhere}.segmented-control{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;padding:4px;background:#edf1ec;border-radius:8px}.segmented-option{min-width:0;padding:0 8px;color:#46524c;background:transparent;font-size:13px;font-weight:700;overflow-wrap:anywhere}.segmented-option.active{color:var(--accent-strong);background:#fff;box-shadow:0 1px 5px #19231e14}.calibration-form{display:grid;gap:12px;margin-top:14px}.compact-form{padding:12px;background:var(--surface-muted);border:1px solid var(--border);border-radius:8px}.status-panel{overflow:hidden}.history-count{color:var(--text-muted);font-size:13px;font-weight:700}.status-main{padding:16px;background:var(--surface-muted);border:1px solid var(--border);border-radius:8px}.status-title-row{display:flex;gap:12px;align-items:flex-start;justify-content:space-between}.status-title-row strong{display:block;margin-top:2px;font-size:34px;line-height:1}.status-type{margin:0;color:var(--text-muted);font-size:13px;font-weight:700}.progress-track{height:12px;margin-top:16px;overflow:hidden;background:#e0e6e1;border-radius:999px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#3b8aa5);border-radius:inherit;transition:width .2s ease}.detail-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px}.summary-tile{min-width:0;padding:12px;background:#fff;border:1px solid var(--border);border-radius:8px}.summary-topline{display:flex;gap:8px;align-items:center;justify-content:space-between}.summary-topline>span:first-child{min-width:0;color:#3f4b45;font-size:13px;font-weight:700}.summary-tile strong{display:block;margin-top:10px;font-size:24px;line-height:1}.summary-tile p{min-height:20px;margin:8px 0 0;color:var(--text-muted);font-size:13px;overflow-wrap:anywhere}.status-board{display:grid;gap:14px;margin-top:14px}.status-group{min-width:0;padding:14px;background:var(--surface-muted);border:1px solid var(--border);border-radius:8px}.status-group-header{display:flex;gap:10px;align-items:center;justify-content:space-between;margin-bottom:10px}.status-group-header h3{margin:0;color:#17211d;font-size:15px;line-height:1.3}.status-group-header span{color:var(--text-muted);font-size:12px;font-weight:700;white-space:nowrap}.target-grid{display:grid;gap:8px}.target-grid-pump,.target-grid-sensor{grid-template-columns:repeat(4,minmax(0,1fr))}.target-grid-result{grid-template-columns:repeat(4,minmax(0,1fr));grid-template-rows:repeat(2,minmax(0,auto));grid-auto-flow:column}.result-machine-grid,.pump-machine-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.result-machine-panel,.pump-machine-panel{min-width:0;padding:10px;background:#fff;border:1px solid var(--border-strong);border-radius:8px}.result-machine-header,.pump-machine-header{display:flex;gap:8px;align-items:center;justify-content:space-between;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border)}.result-machine-header strong,.pump-machine-header strong{color:#17211d;font-size:14px;line-height:1.3}.result-machine-header span,.pump-machine-header span{color:var(--text-muted);font-size:12px;font-weight:700;white-space:nowrap}.result-machine-items,.pump-machine-items{grid-template-columns:1fr}.target-tile{min-width:0;padding:10px;background:#fff;border:1px solid var(--border);border-left-width:4px;border-radius:8px}.target-idle{border-left-color:var(--border-strong)}.target-running{border-left-color:var(--blue)}.target-done{border-left-color:var(--accent)}.target-failed{border-left-color:var(--red)}.target-topline{display:flex;gap:8px;align-items:flex-start;justify-content:space-between}.target-topline>div{min-width:0}.target-topline strong{display:block;color:#17211d;font-size:17px;line-height:1.1;overflow-wrap:anywhere}.target-topline p{min-height:18px;margin:4px 0 0;color:var(--text-muted);font-size:12px;font-weight:700;line-height:1.3;overflow-wrap:anywhere}.mini-progress-track{height:7px;margin-top:10px;overflow:hidden;background:#e0e6e1;border-radius:999px}.mini-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#3b8aa5);border-radius:inherit;transition:width .2s ease}.target-footer{display:flex;gap:8px;align-items:center;justify-content:space-between;margin-top:8px;color:var(--text-muted);font-size:12px;font-weight:700}.target-footer time{min-width:0;text-align:right;overflow-wrap:anywhere}.empty-state{display:grid;min-height:120px;color:var(--text-muted);font-weight:700;background:var(--surface-muted);border:1px dashed var(--border-strong);border-radius:8px;place-items:center}.log-panel{max-height:620px;overflow:hidden}.log-list{display:grid;gap:8px;max-height:520px;overflow:auto;padding-right:4px}.log-item{min-width:0;padding:10px 12px;background:#fbfcfa;border-left:4px solid var(--border-strong);border-radius:6px}.log-incoming{border-left-color:var(--blue)}.log-outgoing,.log-success{border-left-color:var(--accent)}.log-warning{border-left-color:var(--amber)}.log-error{border-left-color:var(--red)}.log-line{display:grid;grid-template-columns:auto auto minmax(0,1fr);gap:8px;align-items:baseline}.log-level{color:#17211d;font-size:12px;font-weight:800}.log-line time{color:var(--text-muted);font-size:12px}.log-line p{min-width:0;margin:0;color:#25302b;font-size:13px;overflow-wrap:anywhere}.log-item pre{max-height:180px;margin:8px 0 0;padding:10px;overflow:auto;color:#26312c;background:#eef2ef;border-radius:6px;font-size:12px;line-height:1.45;white-space:pre-wrap;overflow-wrap:anywhere}@media(max-width:1080px){.app-heading,.workspace-grid{grid-template-columns:1fr}}@media(max-width:720px){.app-shell{padding:14px}.top-status-grid,.summary-grid,.target-grid-result,.result-machine-grid,.pump-machine-grid,.target-grid-pump,.target-grid-sensor,.detail-grid,.form-grid.two-columns,.segmented-control{grid-template-columns:1fr}.span-two{grid-column:auto}.panel{padding:14px}.panel-header,.status-title-row{align-items:flex-start;flex-direction:column}.target-grid-result{grid-template-rows:none;grid-auto-flow:row}.log-line{grid-template-columns:auto minmax(0,1fr)}.log-line p{grid-column:1 / -1}}
