:root{font-family:Inter,SF Pro Text,PingFang SC,Microsoft YaHei,system-ui,sans-serif;color:#172125;background:#eef2f2;font-synthesis:none;text-rendering:optimizeLegibility;--ink: #172125;--muted: #69777a;--line: #d5dede;--surface: #ffffff;--surface-soft: #f5f8f8;--teal: #008f90;--teal-soft: #e4f5f3;--blue: #246b9e;--green: #16845b;--amber: #b36a12;--red: #c73932;--red-soft: #fff0ef}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#eef2f2}button,input{font:inherit}button:focus-visible,input:focus-visible{outline:3px solid rgba(0,143,144,.24);outline-offset:2px}.app-header{min-height:60px;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:6px 24px;color:#fff;background:#16282b;border-bottom:4px solid var(--teal)}.brand-lockup,.header-meta,.status-item,.metric-title,.section-heading,.live-label{display:flex;align-items:center}.brand-lockup{gap:12px}.brand-mark{width:38px;height:38px;display:grid;place-items:center;color:#fff;background:var(--teal);border-radius:5px}.brand-mark svg{width:22px}.brand-lockup h1,.brand-lockup p{margin:0;letter-spacing:0}.brand-lockup h1{font-size:21px;line-height:1.1}.brand-lockup p{margin-top:3px;color:#a9bdbe;font-size:12px}.header-meta{flex-wrap:wrap;justify-content:flex-end;gap:8px;color:#bed0d1;font-size:13px}.header-meta span{display:inline-flex;align-items:center;gap:7px}.header-meta>span,.device-picker{min-height:34px;padding:0 10px;border:1px solid rgba(169,189,190,.24);border-radius:4px;background:#ffffff0a}.device-picker{display:inline-flex;align-items:center;gap:7px;padding-right:0}.device-picker select{max-width:210px;height:34px;padding:0 30px 0 10px;color:#e4eeee;border:1px solid #496064;border-radius:4px;background:#20373a;cursor:pointer}.device-picker select:disabled{cursor:default;opacity:.7}.header-meta svg{width:16px}.header-meta .ws-online{color:#7de1b8}.header-meta .ws-offline{color:#f0bf75}.link-metric{font-size:12px;font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}.link-metric.latency-ok{color:#7de1b8}.link-metric.latency-warn{color:#f0bf75}.link-metric.latency-bad{color:#f08080}main{width:min(1500px,calc(100% - 32px));margin:6px auto 24px}.status-band{min-height:58px;display:grid;grid-template-columns:minmax(180px,1.25fr) repeat(4,minmax(130px,1fr));background:var(--surface);border:1px solid var(--line);border-radius:6px}.status-band>div{min-width:0;padding:9px 18px;border-right:1px solid var(--line)}.status-band>div:last-child{border-right:0}.status-identity,.status-item>div{display:grid;gap:5px}.status-identity small{overflow:hidden;color:var(--muted);font-size:11px;text-overflow:ellipsis;white-space:nowrap}.status-item{gap:11px}.eyebrow{display:block;color:var(--muted);font-size:11px;font-weight:800;line-height:1;letter-spacing:0}.status-band strong{overflow:hidden;font-size:15px;text-overflow:ellipsis;white-space:nowrap}.status-dot{width:10px;height:10px;flex:0 0 10px;border-radius:50%;background:#a9b4b6;box-shadow:0 0 0 4px #edf1f1}.status-dot.is-online{background:var(--green);box-shadow:0 0 0 4px #e4f4ed}.text-ok,.state-running,.state-ready{color:var(--green)}.text-danger,.state-alarm{color:var(--red)}.state-pause,.state-prime{color:var(--amber)}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(390px,.85fr);gap:14px;margin-top:10px}.primary-column,.operations-column{display:grid;align-content:start;gap:14px}.primary-column{grid-template-columns:1fr 1fr}.primary-column>[data-slot=runtime]{grid-column:1 / -1}.panel{background:var(--surface);border:1px solid var(--line);border-radius:6px}.operations-column>[data-slot=control] .panel,.control-actions{border-left:3px solid var(--blue)}.primary-column>[data-slot=runtime] .panel{border-left:3px solid var(--teal)}.operations-column>[data-slot=config] .panel{border-left:3px solid var(--blue)}.operations-column .config-panel .recipe-form{grid-template-columns:repeat(3,minmax(0,1fr))}.operations-column>[data-slot=preset] .panel{border-left:3px solid var(--amber)}.operations-column>[data-slot=history] .panel{border-left:3px solid var(--green)}.primary-column>[data-slot=alarm] .panel{border-left:3px solid var(--green)}.primary-column>[data-slot=alarm] .panel.is-alarm{border-left-color:var(--red)}.section-heading{min-height:48px;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--line)}.section-heading h2{margin:4px 0 0;font-size:17px;line-height:1.1;letter-spacing:0}.section-heading>span,.control-lock{color:var(--muted);font-size:12px}.control-actions{min-height:58px;display:flex;flex-wrap:wrap;gap:10px;padding:10px 16px}.command-button{min-width:116px;height:40px;display:inline-flex;align-items:center;justify-content:center;gap:9px;border:1px solid #bec9ca;border-radius:5px;color:#253236;background:#fff;font-weight:750;cursor:pointer}.command-button svg{width:18px}.command-button.primary{color:#fff;border-color:var(--teal);background:var(--teal)}.command-button.danger{color:#fff;border-color:var(--red);background:var(--red)}.command-button:disabled{cursor:not-allowed;opacity:.42}.live-label{gap:7px}.live-label span{width:7px;height:7px;border-radius:50%;background:var(--green)}.output-summary{padding:14px 16px 4px}.output-summary>div:first-child{display:flex;align-items:baseline;justify-content:space-between}.output-summary span{color:var(--muted);font-size:13px}.output-summary strong{font-size:20px}.progress-track{height:6px;overflow:hidden;margin-top:10px;background:#e5ebeb;border-radius:3px}.progress-track>span{display:block;width:0;height:100%;background:var(--teal);transition:width .26s ease}.runtime-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:12px 16px 14px}.metric-card{min-width:0;padding:12px;background:var(--surface-soft);border:1px solid var(--line);border-radius:5px}.metric-title{justify-content:space-between;gap:8px;color:var(--muted);font-size:12px}.metric-title b{color:var(--blue);font-weight:700}.metric-card>strong{display:block;margin-top:10px;font-size:17px}.metric-card.chemical-a .progress-track>span{background:var(--amber)}.metric-card.chemical-b .progress-track>span{background:var(--blue)}.actuator-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border-top:1px solid var(--line);background:#fafcfc}.actuator-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:11px 8px;text-align:center;border-right:1px solid var(--line);transition:background .25s ease}.actuator-item:last-child{border-right:0}.actuator-item:has(.is-on){background:#16845b0d}.actuator-label{color:var(--muted);font-size:11px;font-weight:600;letter-spacing:.02em}.actuator-state{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:13px;transition:color .2s ease}.actuator-state .state-dot{width:8px;height:8px;flex:0 0 8px;border-radius:50%;background:#b8c4c5;transition:background .2s ease,box-shadow .2s ease}.actuator-state.is-on{color:var(--green)}.actuator-state.is-on .state-dot{background:var(--green);box-shadow:0 0 8px #16845b80;animation:pulse-dot 1.8s ease-in-out infinite}.actuator-state.is-off{color:var(--muted)}.actuator-level{font-size:13px;font-weight:700;color:var(--ink);margin:0}.prop-bar{width:100%;height:4px;margin-top:4px;background:#e5ebeb;border-radius:2px;overflow:hidden}.prop-bar>span{display:block;height:100%;width:0;background:var(--green);border-radius:2px;transition:width .26s ease}.sensor-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;border-top:1px solid var(--line);background:#fff}.sensor-item{min-width:0;padding:10px 12px;border-right:1px solid var(--line)}.sensor-item:last-child{border-right:0}.sensor-item span{display:block;color:var(--muted);font-size:11px;font-weight:700}.sensor-item strong{display:block;overflow:hidden;margin-top:4px;font-size:13px;text-overflow:ellipsis;white-space:nowrap}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.35}}.alarm-panel{border-top:4px solid var(--green)}.alarm-panel.is-alarm{border-color:var(--red);background:var(--red-soft)}.alarm-panel>p{min-height:42px;margin:0;padding:13px 16px;color:#455256;line-height:1.55}.alarm-panel dl{margin:0;border-top:1px solid var(--line)}.alarm-panel dl>div{display:flex;justify-content:space-between;padding:9px 16px;border-bottom:1px solid var(--line)}.alarm-panel dl>div:last-child{border-bottom:0}.alarm-panel dt{color:var(--muted)}.alarm-panel dd{margin:0;font-weight:700}.config-panel .recipe-form{display:grid;grid-template-columns:1fr 1fr;gap:8px 10px;padding:10px 16px 8px}.device-name-setting{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px 10px;padding:9px 16px;border-bottom:1px solid var(--line);background:var(--surface-soft)}.device-name-setting label{min-width:0;color:#465356;font-size:12px;font-weight:700}.device-name-setting input{width:100%;height:32px;margin-top:4px;padding:0 10px;border:1px solid #bec9ca;border-radius:4px;background:#fff}.device-name-setting button{align-self:end;height:32px;padding:0 14px;color:#fff;border:0;border-radius:4px;background:var(--blue);font-weight:750;cursor:pointer}.device-name-setting p{grid-column:1 / -1;min-height:16px;margin:0;color:var(--muted);font-size:12px}.device-name-setting p:empty{display:none}.device-name-setting p.success{color:var(--green)}.device-name-setting p.error{color:var(--red)}.config-panel label{min-width:0;color:#465356;font-size:12px;font-weight:700}.input-unit{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;height:32px;margin-top:4px;border:1px solid #bec9ca;border-radius:4px;background:#fff}.input-unit:focus-within{border-color:var(--teal)}.input-unit input{min-width:0;height:100%;padding:0 9px;border:0;outline:0;background:transparent}.input-unit span{padding:0 9px;color:var(--muted);font-size:11px;border-left:1px solid var(--line)}.save-button{align-self:end;height:32px;color:#fff;border:0;border-radius:4px;background:var(--teal);font-weight:750;cursor:pointer}.save-button:disabled,.input-unit input:disabled{cursor:not-allowed;opacity:.48}.form-message{min-height:20px;margin:0;padding:0 16px 10px;color:var(--muted);font-size:12px}.form-message:empty{display:none}.form-message.success{color:var(--green)}.form-message.error{color:var(--red)}.preset-panel .preset-save{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;padding:8px 16px 6px}.preset-panel .section-heading{min-height:42px;padding-top:8px;padding-bottom:8px}.preset-panel .preset-save input{height:32px;padding:0 10px;border:1px solid #bec9ca;border-radius:4px;background:#fff}.preset-panel .preset-save input:focus{border-color:var(--teal);outline:none}.preset-save-btn{height:32px;padding:0 14px;color:#fff;border:0;border-radius:4px;background:var(--blue);font-weight:700;cursor:pointer;white-space:nowrap}.preset-save-btn:disabled{cursor:not-allowed;opacity:.48}.preset-list{padding:0 16px 6px;max-height:56px;overflow:auto}.preset-list .empty-state{padding:8px 0}.preset-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px solid var(--line)}.preset-row:last-child{border-bottom:0}.preset-info{display:flex;flex-direction:column;gap:2px;min-width:0}.preset-info strong{font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preset-info span{color:var(--muted);font-size:11px}.preset-actions{display:flex;gap:6px;flex-shrink:0}.preset-apply-btn,.preset-delete-btn{height:30px;padding:0 12px;border:1px solid #bec9ca;border-radius:4px;background:#fff;font-size:12px;font-weight:600;cursor:pointer}.preset-apply-btn{color:#fff;border-color:var(--teal);background:var(--teal)}.preset-delete-btn{color:var(--muted)}.preset-delete-btn:hover{color:var(--red);border-color:var(--red)}.history-list{max-height:190px;overflow:auto;padding:0 16px 8px}.history-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line)}.history-row:last-child{border-bottom:0}.history-info{display:grid;gap:2px;min-width:0}.history-info strong,.history-info span,.history-info time{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-info strong{font-size:13px}.history-info span,.history-info time{color:var(--muted);font-size:11px}.history-delete-btn{height:30px;padding:0 12px;color:var(--muted);border:1px solid #bec9ca;border-radius:4px;background:#fff;font-size:12px;font-weight:600;cursor:pointer}.manual-complete-btn{height:32px;padding:0 12px;color:#fff;border:0;border-radius:4px;background:var(--green);font-size:12px;font-weight:750;cursor:pointer;white-space:nowrap}.manual-complete-btn:disabled,.history-delete-btn:disabled{cursor:wait;opacity:.5}.history-delete-btn:hover{color:var(--red);border-color:var(--red)}.activity-section{min-width:0;background:var(--surface);border:1px solid var(--line);border-radius:6px}.section-heading>svg{width:19px;color:var(--teal)}.activity-list{max-height:145px;overflow:auto}.activity-row{display:grid;grid-template-columns:8px minmax(0,1fr) auto;align-items:center;gap:11px;padding:9px 16px;border-bottom:1px solid #e4eaea}.activity-row:last-child{border-bottom:0}.activity-row strong{overflow:hidden;font-size:12px;text-overflow:ellipsis;white-space:nowrap}.activity-row time{color:var(--muted);font-size:11px}.event-mark{width:7px;height:7px;border-radius:50%;background:var(--teal)}.event-mark.alarm{background:var(--red)}.event-mark.offline{background:#8b989a}.event-mark.online,.event-mark.history{background:var(--green)}.event-mark.command,.event-mark.command_ack{background:var(--amber)}.empty-state{padding:16px;color:var(--muted);text-align:center}.toast{position:fixed;right:24px;bottom:24px;z-index:20;max-width:min(380px,calc(100% - 48px));padding:13px 16px;color:#fff;background:#263438;border-radius:5px;box-shadow:0 12px 34px #152a2d3d;opacity:0;pointer-events:none;transform:translateY(10px);transition:.18s ease}.toast.visible{opacity:1;transform:translateY(0)}.toast.success{background:var(--green)}.toast.error{background:var(--red)}.auth-shell{min-height:100vh;width:100%;margin:0;display:grid;place-items:center;padding:24px;background:#eef4f3}.auth-panel{width:min(100%,390px);background:#fff;border:1px solid var(--line);border-radius:8px;padding:28px;box-shadow:0 18px 50px #152a2d29}.auth-brand,.auth-heading,.dialog-heading{display:flex;align-items:center;justify-content:space-between;gap:12px}.auth-brand{justify-content:flex-start;margin-bottom:34px}.auth-brand .language-button{margin-left:auto}.auth-brand h1,.auth-heading h2,.dialog-heading h2{margin:0}.auth-brand p{margin:3px 0 0;color:var(--muted)}.auth-heading{display:block;margin-bottom:18px}.auth-form,.pair-dialog form{display:grid;gap:15px}.auth-form label,.pair-dialog label{display:grid;gap:7px;color:var(--ink);font-size:13px;font-weight:700}.auth-form input,.pair-dialog input{width:100%;min-height:42px;border:1px solid var(--line);border-radius:5px;padding:9px 11px;color:var(--ink);background:#fff}.primary-button{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:5px;background:var(--green);color:#fff;font-weight:800;cursor:pointer}.text-button{width:100%;margin-top:18px;border:0;background:transparent;color:var(--green);cursor:pointer}.form-error{min-height:18px;margin:0;color:var(--red);font-size:12px}.header-action,.account-name{min-height:32px;display:inline-flex;align-items:center;gap:6px}.header-action{border:1px solid rgba(255,255,255,.28);border-radius:5px;padding:5px 9px;background:transparent;color:#fff;cursor:pointer}.header-action.danger-action{color:#ffc3bf;border-color:#ffc3bf52}.header-action:disabled{opacity:.42;cursor:not-allowed}.header-action.icon-button{width:32px;padding:5px;justify-content:center}.language-button,.dialog-close-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);border-radius:5px;background:#fff;color:var(--ink);cursor:pointer}.language-button{min-height:32px;padding:5px 9px;color:var(--green);font-weight:800}.language-button svg,.dialog-close-button svg{width:17px;height:17px}.dialog-close-button{width:34px;height:34px;padding:0;color:var(--muted);background:var(--surface-soft)}.dialog-close-button:hover{color:var(--ink);border-color:#aebbbc}.pair-dialog{width:min(100% - 24px,420px);border:1px solid var(--line);border-radius:8px;padding:22px;color:var(--ink)}.pair-dialog::backdrop{background:#11222585}.dialog-heading{margin-bottom:8px}.device-empty{min-height:300px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:22px;padding:32px;border:1px solid var(--line);background:var(--surface)}.device-empty[hidden],[data-field=device-content][hidden]{display:none}.device-empty>svg{width:42px;height:42px;color:var(--teal)}.device-empty h2,.device-empty p{margin:3px 0}.device-empty p{color:var(--muted)}@media(max-width:980px){.status-band{grid-template-columns:repeat(2,1fr)}.status-band>div{border-bottom:1px solid var(--line)}.dashboard-grid,.primary-column{grid-template-columns:1fr}.operations-column{order:-1}}@media(max-width:680px){.app-header{height:auto;align-items:flex-start;flex-direction:column;padding:15px 18px}.header-meta{justify-content:flex-start;width:100%;text-align:left}.header-meta>span,.device-picker{width:100%;justify-content:flex-start}.device-picker select{max-width:none;width:100%}main{width:min(100% - 20px,1480px);margin-top:10px}.status-band,.runtime-grid,.config-panel .recipe-form,.device-name-setting{grid-template-columns:1fr}.status-band>div{border-right:0}.control-actions{display:grid;grid-template-columns:1fr 1fr}.command-button,.command-button.danger{width:100%;min-width:0;margin-left:0}.actuator-strip{grid-template-columns:repeat(3,1fr)}.sensor-strip{grid-template-columns:repeat(2,1fr)}.actuator-item:nth-child(3n){border-right:0}.activity-row{grid-template-columns:8px minmax(0,1fr)}.activity-row time{grid-column:2}.device-empty{grid-template-columns:1fr;justify-items:start}}
