:root{--bg:#060d16;--bg-2:#0a1520;--bg-3:#0f1d2d;--card-bg:#0c1824;--card-border:#142235;--card-hi:#1c2f45;--text:#5d7a96;--text-2:#8aa4be;--text-h:#cfe0f0;--text-dim:#2e4a62;--accent:#2f7dff;--accent-2:#69adff;--accent-glow:#2f7dff59;--accent-dim:#2f7dff1f;--cyan:#64b8ff;--cyan-dim:#64b8ff1f;--cyan-glow:#64b8ff4d;--success:#4f9fff;--success-dim:#4f9fff1f;--warning:#3d8dff;--warning-dim:#3d8dff1f;--danger:#246bff;--danger-dim:#246bff1f;--border:#142235;--border-hi:#1e3550;--font-display:"Rajdhani", sans-serif;--font-mono:"JetBrains Mono", monospace;--font-body:"DM Sans", sans-serif;--radius:10px;--radius-sm:6px;--shadow:0 4px 24px #0006;--shadow-card:0 2px 12px #00000080, inset 0 1px 0 #ffffff08}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg);color:var(--text);background-image:radial-gradient(circle at 1px 1px,#00c8ff0f 1px,#0000 0);background-size:28px 28px;background-attachment:fixed;min-height:100vh;font-size:14px;line-height:1.5}body:before{content:"";pointer-events:none;z-index:999;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#0000000a 2px 4px);position:fixed;inset:0}.app{flex-direction:column;gap:12px;max-width:1100px;margin:0 auto;padding:10px 16px 28px;display:flex}.app-header{text-align:center;background:0 0;place-content:center;align-items:center;padding:4px 20px;animation:.4s slideDown;display:flex}.header-logo-pill{background:#fffffff5;border:1px solid #ffffffb3;border-radius:18px;justify-content:center;align-items:center;padding:4px 12px;display:inline-flex;box-shadow:0 4px 14px #00000024}.header-left{align-items:center;gap:12px;display:flex}.header-logo{flex-shrink:0;width:64px;height:auto;display:block}.header-title{font-family:var(--font-display);letter-spacing:.12em;color:var(--text-h);text-transform:uppercase;font-size:22px;font-weight:700}.header-title span{color:var(--accent)}.app-icon{vertical-align:middle;flex-shrink:0;display:inline-block}.widget-title-icon{width:17px;height:17px;color:var(--accent)}.btn-icon{color:currentColor;width:15px;height:15px;position:relative;top:-1px}.btn-icon.led-red,.btn-icon.led-green,.btn-icon.led-blue{color:var(--accent)}.header-meta{align-items:center;gap:16px;display:flex}.header-badge{font-family:var(--font-mono);color:var(--cyan);background:var(--cyan-dim);letter-spacing:.08em;text-transform:uppercase;border:1px solid #00c8ff33;border-radius:4px;padding:3px 8px;font-size:10px}.header-version{font-family:var(--font-mono);color:var(--text-dim);letter-spacing:.06em;font-size:11px}.navigation{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:6px;animation:.45s slideDown}.navigation ul{gap:4px;list-style:none;display:flex}.navigation ul li{flex:1}.navigation a{text-align:center;color:var(--text);border-radius:var(--radius-sm);font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-size:15px;font-weight:600;text-decoration:none;transition:all .18s;display:flex;position:relative;overflow:hidden}.nav-icon{opacity:.7;font-size:16px}.navigation a:hover{background:var(--bg-3);color:var(--text-h)}.navigation a.active{background:var(--accent-dim);color:var(--accent);box-shadow:0 0 12px var(--accent-glow);border:1px solid #2f7dff33}.navigation a.active .nav-icon{opacity:1}.page{flex-direction:column;gap:14px;animation:.3s fadeIn;display:flex}.page-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:20px;transition:border-color .3s;position:relative;overflow:hidden}.card:before{content:"";background:linear-gradient(90deg, var(--accent) 0%, transparent 100%);opacity:.5;height:2px;position:absolute;top:0;left:0;right:0}.card.accent-cyan:before{background:linear-gradient(90deg, var(--cyan) 0%, transparent 100%)}.card.accent-success:before{background:linear-gradient(90deg, var(--success) 0%, transparent 100%)}.card:hover{border-color:var(--border-hi)}.card.loading{text-align:center;color:var(--text-dim);font-family:var(--font-mono);letter-spacing:.1em;padding:48px;font-size:12px}.card.loading:after{content:"";border:2px solid var(--border-hi);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;margin:16px auto 0;animation:.8s linear infinite spin;display:block}.card.error{background:var(--danger-dim);color:var(--danger);font-family:var(--font-mono);border-color:#246bff4d;font-size:12px}.card-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.card-title{font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;color:var(--text-h);align-items:center;gap:8px;font-size:17px;font-weight:700;display:flex}.card-title-icon{font-size:18px}.card-tag{font-family:var(--font-mono);color:var(--text-dim);background:var(--bg-3);border:1px solid var(--border);letter-spacing:.08em;text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:10px}.section{border-top:1px solid var(--border);margin-top:18px;padding-top:16px}.section-title{font-family:var(--font-display);letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);margin-bottom:12px;font-size:13px;font-weight:600}.info-grid{flex-direction:column;gap:8px;display:flex}.info-item{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.info-label{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);font-size:11px}.info-value{font-family:var(--font-mono);color:var(--text-h);font-size:14px;font-weight:500}.info-value.large{color:var(--accent);letter-spacing:.04em;font-feature-settings:"tnum";font-size:32px;font-weight:600;line-height:1}.info-value.date{font-family:var(--font-display);color:var(--text-2);font-size:15px;font-weight:500}.info-value.ip{color:var(--cyan)}.btn{background:var(--bg-3);border:1px solid var(--border-hi);color:var(--text-2);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;justify-content:center;align-items:center;gap:6px;padding:10px 18px;font-size:14px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex;position:relative;overflow:hidden}.btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);box-shadow:0 0 8px var(--accent-glow)}.btn.btn-accent{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 14px var(--accent-glow)}.btn.btn-accent:hover{background:var(--accent-2);box-shadow:0 0 20px var(--accent-glow)}.btn.btn-danger{background:var(--danger-dim);color:var(--danger);border-color:#246bff4d}.btn.btn-danger:hover{background:var(--danger);color:#fff;box-shadow:0 0 12px #246bff66}.btn.btn-danger:disabled{opacity:.3;cursor:not-allowed;box-shadow:none}.btn.btn-cyan{background:var(--cyan-dim);color:var(--cyan);border-color:#00c8ff33}.btn.btn-cyan:hover{background:var(--cyan);color:#060d16;box-shadow:0 0 12px var(--cyan-glow)}.refresh-btn{border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-mono);letter-spacing:.08em;background:0 0;padding:5px 12px;font-size:11px;transition:all .15s}.refresh-btn:hover{border-color:var(--cyan);color:var(--cyan)}.sim-button-group{grid-template-columns:1fr 1fr;gap:10px;display:grid}.sim-btn{background:var(--bg-2);border:1px solid var(--border-hi);color:var(--text-2);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:18px 12px;font-weight:600;transition:all .18s;display:flex;position:relative;overflow:hidden}.sim-btn-icon{font-size:24px}.sim-btn-label{font-size:13px}.sim-btn-sub{font-size:10px;font-family:var(--font-mono);color:var(--text-dim);letter-spacing:.06em;font-weight:400}.sim-btn:hover{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.sim-btn.sim-active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent);box-shadow:0 0 16px var(--accent-glow), inset 0 0 30px #2f7dff0d;animation:2s ease-in-out infinite simPulse}.sim-btn.sim-active .sim-btn-sub{color:var(--accent)}.actuator-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.actuator-item{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;padding:16px 12px;transition:all .2s}.actuator-item.active{background:var(--success-dim);border-color:#4f9fff4d;box-shadow:0 0 10px #4f9fff26}.actuator-icon{margin-bottom:6px;font-size:22px}.actuator-label{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--text-2);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.actuator-badge{font-family:var(--font-mono);letter-spacing:.06em;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.actuator-badge.on{background:var(--success-dim);color:var(--success);border:1px solid #4f9fff33}.actuator-badge.off{background:var(--bg-3);color:var(--text-dim);border:1px solid var(--border)}.led-display{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;gap:10px;margin-top:12px;padding:12px 14px;display:flex}.led-label{font-family:var(--font-mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;font-size:11px}.led-dot{background:var(--text-dim);width:16px;height:16px;box-shadow:none;border-radius:50%;transition:all .3s}.led-dot.red{background:var(--accent);box-shadow:0 0 8px #2f7dff99}.led-dot.green{background:var(--success);box-shadow:0 0 8px #4f9fff99}.led-dot.blue{background:var(--cyan);box-shadow:0 0 8px var(--cyan-glow)}.led-dot.earthquake{background:var(--warning);animation:.5s step-end infinite blink;box-shadow:0 0 8px #3d8dff99}.led-dot.off{background:var(--text-dim)}.led-color-name{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-2);font-size:12px;font-weight:600}.actuator-control-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.act-btn{background:var(--bg-2);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-mono);letter-spacing:.06em;justify-content:center;align-items:center;gap:6px;padding:9px 12px;font-size:11px;transition:all .15s;display:flex}.act-btn:hover{border-color:var(--border-hi);color:var(--text-h);background:var(--bg-3)}.act-btn.on:hover{color:var(--success);background:var(--success-dim);border-color:#4f9fff4d}.act-btn.off:hover{color:var(--danger);background:var(--danger-dim);border-color:#246bff4d}.led-btn-group{flex-wrap:wrap;gap:6px;display:flex}.led-btn{background:var(--bg-2);border:1px solid var(--border);min-width:70px;color:var(--text);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-mono);letter-spacing:.04em;flex:1;justify-content:center;align-items:center;gap:5px;padding:9px 6px;font-size:11px;transition:all .15s;display:flex}.led-btn:hover{background:var(--bg-3);color:var(--text-h);border-color:var(--border-hi)}.connection-bar{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-mono);letter-spacing:.06em;color:var(--text-dim);align-items:center;gap:8px;margin-bottom:16px;padding:8px 12px;font-size:11px;display:flex}.connection-bar.is-connected{background:var(--success-dim);color:var(--success);border-color:#4f9fff33}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-dot.connected{background:var(--success);box-shadow:0 0 6px var(--success);animation:2s ease-in-out infinite pulse}.status-dot.disconnected{background:var(--danger)}.event-display{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;gap:12px;margin-top:14px;padding:14px;display:flex}.event-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);font-size:10px}.event-value{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--text-2);font-size:16px;font-weight:700}.event-value.active{color:var(--accent);text-shadow:0 0 12px var(--accent-glow)}.device-list{flex-direction:column;gap:6px;display:flex}.device-item{background:var(--bg-2);border:1px solid var(--border);border-left:3px solid var(--border);border-radius:var(--radius-sm);grid-template-columns:1fr auto auto;align-items:center;gap:12px;padding:12px 14px;transition:all .15s;display:grid}.device-item:hover{background:var(--bg-3)}.device-item.online{border-left-color:var(--success)}.device-item.warning{border-left-color:var(--warning)}.device-item.offline{border-left-color:var(--danger)}.device-version{font-family:var(--font-mono);color:var(--cyan);background:var(--cyan-dim);border:1px solid #00c8ff26;border-radius:4px;padding:2px 7px;font-size:11px}.device-status-badge{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;border-radius:4px;padding:3px 8px;font-size:10px}.device-status-badge.online{background:var(--success-dim);color:var(--success);border:1px solid #4f9fff33}.device-status-badge.warning{background:var(--warning-dim);color:var(--warning);border:1px solid #3d8dff33}.device-status-badge.offline{background:var(--danger-dim);color:var(--danger);border:1px solid #246bff33}.service-list{flex-direction:column;gap:6px;display:flex}.service-item{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);grid-template-columns:auto 1fr auto auto;align-items:center;gap:12px;padding:11px 14px;transition:all .15s;display:grid}.service-item.online .service-dot{background:var(--success);box-shadow:0 0 6px var(--success);animation:2.5s ease-in-out infinite pulse}.service-item.offline .service-dot{background:var(--danger)}.service-item.checking .service-dot{background:var(--warning);animation:.8s step-end infinite blink}.service-name{font-family:var(--font-mono);color:var(--text-h);font-size:12px;font-weight:500}.service-latency{font-family:var(--font-mono);color:var(--success);font-size:12px}.service-status{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-size:10px}.service-item.online .service-status{color:var(--success)}.service-item.offline .service-status{color:var(--danger)}.service-item.checking .service-status{color:var(--warning)}.ota-stats{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px;display:grid}.ota-stat{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;padding:14px}.ota-stat-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin-bottom:8px;font-size:10px;display:block}.ota-stat-value{font-family:var(--font-display);color:var(--text-h);letter-spacing:.04em;font-size:22px;font-weight:700}.ota-stat-value.ok{color:var(--success)}.empty{text-align:center;color:var(--text-dim);font-family:var(--font-mono);letter-spacing:.08em;padding:24px;font-size:12px}.info-text{color:var(--text-dim);font-size:13px;line-height:1.6;font-family:var(--font-mono);margin-bottom:12px}.last-check{font-family:var(--font-mono);color:var(--text-dim);letter-spacing:.04em;margin-bottom:10px;font-size:11px}.device-last-seen{font-family:var(--font-mono);color:var(--text-dim);font-size:11px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 4px}50%{opacity:.7;box-shadow:0 0 10px}}@keyframes simPulse{0%,to{box-shadow:0 0 8px var(--accent-glow)}50%{box-shadow:0 0 22px var(--accent-glow)}}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-container{width:100%}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;animation:.4s fadeIn;display:grid}.dashboard-item{cursor:pointer;transition:all .2s}.dashboard-item:hover .widget-card{border-color:var(--border-hi);box-shadow:0 0 16px #00c8ff1a, var(--shadow-card);transform:translateY(-2px)}.widget-card{cursor:pointer;flex-direction:column;gap:12px;transition:all .18s;display:flex}.widget-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.widget-header h3{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--text-h);font-size:14px;font-weight:700}.badge{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;background:var(--cyan-dim);color:var(--cyan);white-space:nowrap;border:1px solid #00c8ff33;border-radius:4px;align-items:center;gap:4px;padding:3px 8px;font-size:10px;display:inline-flex}.badge.connected{background:var(--success-dim);color:var(--success);border-color:#4f9fff33}.badge.disconnected{background:var(--danger-dim);color:var(--danger);border-color:#246bff33}.widget-body{flex-direction:column;gap:10px;display:flex}.widget-stat{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:8px 10px;display:flex}.stat-label{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim);font-size:11px}.stat-value{font-family:var(--font-mono);color:var(--text-h);font-size:14px;font-weight:600}.stat-value.mono{color:var(--cyan)}.stat-value.status-ok{color:var(--success)}.widget-note{font-family:var(--font-mono);color:var(--text-dim);letter-spacing:.04em;margin-top:2px;font-size:10px}.widget-preview{flex-direction:column;gap:6px;display:flex}.preview-item{background:var(--bg-3);border:1px solid var(--border);border-left:3px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:8px 10px;font-size:12px;display:flex}.preview-item.online{border-left-color:var(--success)}.preview-item.warning{border-left-color:var(--warning)}.preview-item.offline{border-left-color:var(--danger)}.device-id{font-family:var(--font-mono);color:var(--text-h);font-size:12px;font-weight:500}.device-status{font-family:var(--font-mono);color:var(--text-dim);font-size:11px}.more-text{text-align:center;font-family:var(--font-mono);color:var(--text-dim);padding:4px;font-size:10px;font-style:italic}.quick-actions{grid-template-columns:1fr 1fr;gap:6px;display:grid}.btn-mini{background:var(--bg-3);border:1px solid var(--border-hi);color:var(--text-2);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;padding:6px 8px;font-size:11px;transition:all .15s}.btn-mini:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);box-shadow:0 0 8px var(--accent-glow)}.btn-mini.selected{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.simulation-readout{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.sim-readout-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:10px;min-height:72px;padding:14px;display:flex}.sim-readout-card.active{border-color:var(--accent);background:var(--accent-dim)}.sim-readout-card strong{font-family:var(--font-display);color:var(--text-h);letter-spacing:.04em;text-transform:uppercase;margin-top:3px;font-size:16px;display:block}.sim-readout-icon{color:var(--accent)}.status-text,.error-text,.empty-text{font-family:var(--font-mono);color:var(--text-dim);margin-top:10px;font-size:12px}.error-text{color:var(--danger)}.server-control-panel{grid-template-columns:1.2fr 1fr;gap:10px;margin-bottom:12px;display:grid}.server-endpoint,.server-body-preview{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.server-endpoint{flex-direction:column;gap:8px;padding:12px 14px;display:flex}.server-endpoint code,.server-body-preview{font-family:var(--font-mono);color:var(--cyan);white-space:pre-wrap;word-break:break-word;font-size:11px}.server-body-preview{color:var(--text-2);margin:0;padding:12px 14px}.actuator-grid-mini{grid-template-columns:1fr 1fr 1fr;gap:6px;display:grid}.actuator-mini{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-mono);text-align:center;color:var(--text-dim);flex-direction:column;align-items:center;gap:4px;padding:6px 4px;font-size:10px;display:flex}.actuator-mini.active{background:var(--success-dim);color:var(--success);border-color:#4f9fff4d}.actuator-dot{background:var(--text-dim);border-radius:50%;width:6px;height:6px}.actuator-mini.active .actuator-dot{background:var(--success);box-shadow:0 0 4px var(--success)}.service-grid-mini{flex-direction:column;gap:6px;display:flex}.service-mini{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-mono);color:var(--text-dim);align-items:center;gap:6px;padding:6px 8px;font-size:11px;display:flex}.service-mini.online{background:var(--success-dim);color:var(--success);border-color:#4f9fff33}.service-mini.offline{background:var(--danger-dim);color:var(--danger);border-color:#246bff33}.service-dot{background:currentColor;border-radius:50%;flex-shrink:0;width:6px;height:6px}.service-name{flex:1;font-weight:500}.service-more{text-align:center;font-family:var(--font-mono);color:var(--text-dim);padding:4px 8px;font-size:10px;font-style:italic}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;background:#060d16b3;justify-content:center;align-items:center;padding:16px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;width:100%;max-width:800px;max-height:85vh;animation:.3s slideDown;display:flex;box-shadow:0 20px 60px #0009}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:20px;display:flex}.modal-header h2{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--text-h);margin:0;font-size:18px;font-weight:700}.modal-close{border:1px solid var(--border);width:32px;height:32px;color:var(--text-dim);border-radius:var(--radius-sm);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;transition:all .15s;display:flex}.modal-close:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.modal-body{flex:1;padding:20px;overflow-y:auto}.modal-body .info-grid,.modal-body .device-list,.modal-body .service-list,.modal-body .ota-status,.modal-body .button-group,.modal-body .section{margin-bottom:16px}.modal-body .section h3{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--text-h);margin-bottom:12px;font-size:14px;font-weight:700}@media (width<=700px){.dashboard-grid,.page-grid{grid-template-columns:1fr}.modal-content{max-height:90vh}.page-grid{grid-template-columns:1fr}.actuator-grid{grid-template-columns:1fr 1fr}.ota-stats{grid-template-columns:1fr}.sim-button-group{grid-template-columns:1fr 1fr}.header-meta{display:none}.app-header h1{font-size:18px}.navigation a{padding:10px 8px;font-size:12px}.nav-icon{display:none}.service-item{grid-template-columns:auto 1fr auto}.service-latency{display:none}.server-control-panel,.simulation-readout{grid-template-columns:1fr}}
