:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#18202a;background:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}.app-shell{width:min(1120px,calc(100% - 32px));margin:0 auto;padding:32px 0}.app-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.eyebrow,.label{color:#5f6b7a;font-size:.78rem;font-weight:700;letter-spacing:0;text-transform:uppercase}h1,h2{margin:0;letter-spacing:0}h1{color:#111827;font-size:clamp(2rem,5vw,3.4rem);line-height:1}h2{font-size:1.05rem}.status-pill{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:0 14px;color:#4b5563;background:#fff;border:1px solid #dbe2ea;border-radius:999px;font-weight:700;white-space:nowrap}.status-pill.connected{color:#0f766e;border-color:#99d5cb;background:#effaf7}.notice{display:flex;align-items:center;gap:10px;min-height:46px;margin-bottom:14px;padding:12px 14px;border-radius:8px;border:1px solid;font-weight:650}.notice.error{color:#9f1239;background:#fff1f2;border-color:#fecdd3}.notice.warning{color:#8a4b0a;background:#fffbeb;border-color:#fde68a}.notice button{margin-left:auto;color:inherit;background:transparent;border:0;font-weight:800}.device-strip,.panel{background:#fff;border:1px solid #dce3eb;border-radius:8px;box-shadow:0 16px 42px #10182812}.device-strip{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;padding:14px}.device-main{display:flex;align-items:center;gap:12px;min-width:0}.device-main strong{display:block;overflow-wrap:anywhere}.device-icon{display:grid;width:44px;height:44px;place-items:center;color:#0f766e;background:#e9f7f4;border-radius:8px}.device-actions,.action-stack{display:flex;gap:10px}.device-actions{flex-wrap:wrap;justify-content:flex-end}.content-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:16px;align-items:start}.panel{padding:18px}.panel-title{display:flex;align-items:center;gap:10px;margin-bottom:18px;color:#111827}.panel-title svg{color:#0f766e}.control-stack,.action-stack{flex-direction:column}.control-row{display:grid;grid-template-columns:minmax(180px,1fr) minmax(260px,420px);gap:18px;align-items:center;min-height:66px;padding:14px 0;border-top:1px solid #e7edf3}.control-row:first-child{border-top:0}.control-row strong{display:block;line-height:1.25}.control-row small{display:block;margin-top:5px;color:#be123c;font-weight:650}.control-row.invalid input[type=number]{border-color:#fb7185}.range-inputs{display:grid;grid-template-columns:minmax(130px,1fr) 84px;gap:12px;align-items:center}input[type=range]{width:100%;accent-color:#0f766e}input[type=number]{width:100%;min-height:38px;padding:0 10px;color:#111827;background:#fbfcfd;border:1px solid #cfd8e3;border-radius:6px;font-weight:750}.toggle-row{min-height:58px}.switch{justify-self:end;position:relative;width:56px;height:32px;padding:3px;background:#cbd5e1;border:0;border-radius:999px;transition:background-color .16s ease}.switch span{display:block;width:26px;height:26px;background:#fff;border-radius:50%;box-shadow:0 2px 6px #0f172a33;transition:transform .16s ease}.switch.on{background:#0f766e}.switch.on span{transform:translate(24px)}.segmented-control{display:grid;grid-template-columns:repeat(3,1fr);padding:4px;background:#eef2f6;border-radius:8px}.segmented-control button{min-height:36px;color:#526070;background:transparent;border:0;border-radius:6px;font-weight:800}.segmented-control button.selected{color:#0f3f3b;background:#fff;box-shadow:0 1px 5px #1018281f}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;padding:0 14px;border:1px solid transparent;border-radius:7px;font-weight:850;transition:transform .12s ease,background-color .12s ease,border-color .12s ease}.button:not(:disabled):active{transform:translateY(1px)}.button.primary{color:#fff;background:#0f766e}.button.primary:hover:not(:disabled){background:#0d5f59}.button.success{color:#fff;background:#2563eb}.button.success:hover:not(:disabled){background:#1d4ed8}.button.secondary,.button.ghost{color:#253140;background:#fff;border-color:#cfd8e3}.button.secondary:hover:not(:disabled),.button.ghost:hover:not(:disabled){background:#f5f8fb}.button.ghost{color:#5f6b7a}.button:disabled{opacity:.48}.button.wide{width:100%}.state-box{margin-top:18px;padding:14px;background:#f8fafc;border:1px solid #e0e7ef;border-radius:8px}.state-box strong{display:block;margin-top:4px}.state-box ul{margin:10px 0 0;padding-left:18px;color:#be123c;font-weight:650}@media (max-width: 860px){.app-shell{width:min(100% - 20px,680px);padding:20px 0}.app-header,.device-strip{align-items:stretch;flex-direction:column}.status-pill{align-self:flex-start}.device-actions{justify-content:stretch}.device-actions .button{flex:1 1 140px}.content-grid{grid-template-columns:1fr}.control-row{grid-template-columns:1fr;gap:10px}}@media (max-width: 480px){.range-inputs,.segmented-control{grid-template-columns:1fr}.panel{padding:14px}}
