:root{color:#132e40;font-synthesis:none;background:#f3f7fa;font-family:Noto Sans SC,Microsoft YaHei,Arial,sans-serif}*{box-sizing:border-box}body{min-width:280px;margin:0}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:wait;opacity:.6}.login-page{background:linear-gradient(150deg,#0e4665 0 34%,#f3f7fa 34%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card,.summary-card,.control-card{background:#fff;border-radius:20px;padding:24px;box-shadow:0 12px 36px #112d4017}.login-card{gap:14px;width:100%;max-width:380px;display:grid}.brand{color:#0e4665;letter-spacing:.18em;margin:0;font-size:14px;font-weight:700}h1,h2,p{margin:0}h1{font-size:24px}h2{margin-bottom:20px;font-size:18px}.muted,.label{color:#648092;font-size:13px}.input{border:1px solid #d5e0e7;border-radius:12px;height:48px;padding:0 14px}.input:focus{border-color:#0e6c8e;outline:2px solid #0e6c8e26}.primary{color:#fff;background:#0e6684;border:0;border-radius:12px;height:48px;padding:0 18px}.full{width:100%}.page{max-width:560px;min-height:100vh;padding:calc(12px + env(safe-area-inset-top)) 16px 32px;margin:0 auto}.header{justify-content:space-between;align-items:center;gap:12px;min-height:44px;margin-bottom:20px;display:flex}.header h1{flex:1}.plain{color:#0e6684;background:0 0;border:0;padding:8px 2px}.device-list{gap:12px;display:grid}.device-card{text-align:left;background:#fff;border:0;border-radius:16px;padding:18px;box-shadow:0 4px 15px #112d400f}.device-title,.row{justify-content:space-between;align-items:center;display:flex}.temperature{margin:16px 0 8px;font-size:30px;font-weight:700}.badge{border-radius:999px;padding:5px 10px;font-size:12px}.online{color:#157c40;background:#e7f6ec}.offline,.error{color:#ae3434;background:#fdecec}.warning{color:#996000;background:#fff3dd}.summary-card,.control-card{margin-bottom:16px}.values{grid-template-columns:1fr 1fr;gap:10px;margin:20px 0;display:grid}.value-card{background:#f4f8fa;border-radius:12px;padding:14px}.value-card strong{margin-top:8px;font-size:26px;display:block}.adjust{justify-content:center;align-items:center;gap:24px;margin:16px 0 24px;display:flex}.round{color:#0e6684;background:#e9f2f6;border:0;border-radius:50%;width:56px;height:56px;font-size:30px}.setpoint{text-align:center;min-width:140px;font-size:38px}.notice{text-align:center;border-radius:10px;min-height:20px;margin-top:12px;padding:8px 10px}.notice:empty{padding:0}.empty{color:#648092;text-align:center;padding:48px 0}
