*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Microsoft YaHei",Arial,sans-serif;background:#f5f7fb;color:#1f2937;font-size:12px}a{color:#2563eb;text-decoration:none}code{background:#f1f5f9;padding:2px 5px;border-radius:6px;color:#0f172a}.layout{display:flex;min-height:100vh}.sidebar{width:180px;background:#111827;color:#fff;padding:16px 12px;position:sticky;top:0;height:100vh}.brand{font-size:16px;font-weight:700;margin-bottom:20px}.sidebar nav a{display:block;color:#cbd5e1;padding:10px 12px;border-radius:10px;margin:4px 0}.sidebar nav a:hover,.sidebar nav a.active{background:#2563eb;color:#fff}.main{flex:1;padding:18px;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.topbar h1{font-size:20px;margin:0}.card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;margin-bottom:16px;box-shadow:0 8px 22px rgba(15,23,42,.04)}.grid{display:grid;gap:14px}.cards4{grid-template-columns:repeat(4,minmax(0,1fr))}.stat b{display:block;font-size:24px}.stat span{color:#64748b}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:end}.form-stack{display:grid;gap:12px}.form-grid label,.form-stack label{display:grid;gap:6px;color:#475569}.form-grid .wide{grid-column:1/-1}input,select,textarea{width:100%;height:36px;border:1px solid #cbd5e1;border-radius:10px;padding:0 10px;background:#fff;color:#0f172a;font-size:12px}textarea{height:auto;padding:10px}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 14px;border:1px solid #cbd5e1;background:#fff;color:#1f2937;border-radius:10px;cursor:pointer;font-size:12px}.btn:hover{background:#f8fafc}.btn.primary{background:#2563eb;border-color:#2563eb;color:#fff}.btn.danger{background:#dc2626;border-color:#dc2626;color:#fff}.btn.small{min-height:28px;padding:0 9px}.btn:disabled,button:disabled{opacity:.5;cursor:not-allowed}.alert{border-radius:12px;padding:11px 14px;margin-bottom:14px;border:1px solid #e5e7eb;background:#fff}.alert.success{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.alert.error{background:#fef2f2;border-color:#fecaca;color:#991b1b}.alert.warning{background:#fffbeb;border-color:#fde68a;color:#92400e}.muted{color:#64748b}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}th,td{padding:10px 8px;border-bottom:1px solid #e5e7eb;text-align:left;vertical-align:middle}th{color:#475569;background:#f8fafc;font-weight:600}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:3px 8px;font-size:12px;background:#e5e7eb;color:#374151}.badge.green{background:#dcfce7;color:#166534}.badge.red{background:#fee2e2;color:#991b1b}.badge.gray{background:#e5e7eb;color:#374151}.inline-form{display:inline-flex;gap:8px;align-items:center;flex-wrap:wrap}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.install-box,.login-box{max-width:780px;margin:40px auto;padding:18px}.login-box{max-width:420px}.client-main{max-width:1080px;margin:0 auto;padding:18px}.hero{text-align:center;padding:38px 20px}.client-head{display:flex;align-items:center;justify-content:space-between;gap:14px}.client-head h1{margin:0 0 6px}.device-title{display:flex;align-items:center;justify-content:space-between;gap:12px}.control-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.control-card{border:1px solid #e5e7eb;border-radius:14px;padding:14px;background:#fafafa}.control-card h3{margin:0 0 10px;font-size:15px}.sensor-num{font-size:20px;font-weight:700;margin:8px 0}.remote-pad{display:grid;grid-template-columns:repeat(3,54px);grid-template-rows:repeat(3,42px);gap:6px;justify-content:center}.remote-pad button{border:1px solid #cbd5e1;background:#fff;border-radius:12px;cursor:pointer}.remote-pad button:active,.remote-pad button.pressed{background:#2563eb;color:#fff}.remote-pad button[data-btn="forward"]{grid-column:2;grid-row:1}.remote-pad button[data-btn="left"]{grid-column:1;grid-row:2}.remote-pad button[data-btn="right"]{grid-column:3;grid-row:2}.remote-pad button[data-btn="backward"]{grid-column:2;grid-row:3}.prose pre{background:#0f172a;color:#e5e7eb;padding:14px;border-radius:12px;overflow:auto}.hidden{display:none!important}.empty{text-align:center;color:#64748b;padding:30px}.flash-hide{opacity:0;transition:.3s}
@media(max-width:760px){.layout{display:block}.sidebar{width:100%;height:auto;position:static}.sidebar nav{display:flex;overflow:auto;gap:6px}.sidebar nav a{white-space:nowrap}.main{padding:12px}.cards4,.form-grid,.detail-grid{grid-template-columns:1fr}.client-main{padding:12px}.client-head{align-items:flex-start}.table-wrap table{min-width:760px}.control-grid{grid-template-columns:1fr}}
