.admin-overlay[data-v-24441f9e]{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:1000;display:flex;justify-content:flex-end}.admin-drawer[data-v-24441f9e]{width:min(420px,100vw);height:100dvh;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}.drawer-header[data-v-24441f9e]{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.1rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}.drawer-title[data-v-24441f9e]{font-weight:700;font-size:.95rem}.btn-icon[data-v-24441f9e]{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:.2rem .5rem;border-radius:4px}.btn-icon[data-v-24441f9e]:hover{color:var(--text)}.login-section[data-v-24441f9e]{padding:2rem 1.25rem;display:flex;flex-direction:column;gap:.9rem}.hint[data-v-24441f9e]{font-size:.8rem;color:var(--text-muted);line-height:1.5}.row[data-v-24441f9e]{display:flex;gap:.5rem}.field[data-v-24441f9e]{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:7px;padding:.55rem .8rem;color:var(--text);font-size:.88rem;outline:none;transition:border-color .15s;box-sizing:border-box}.field[data-v-24441f9e]:focus{border-color:var(--blue)}.field-sm[data-v-24441f9e]{font-size:.82rem;padding:.42rem .7rem}.tab-bar[data-v-24441f9e]{display:flex;align-items:center;gap:.2rem;padding:.65rem .85rem;border-bottom:1px solid var(--border);flex-shrink:0}.tab-btn[data-v-24441f9e]{padding:.3rem .7rem;font-size:.78rem;border-radius:6px;border:1px solid transparent;cursor:pointer;background:none;color:var(--text-muted);transition:all .15s}.tab-btn.active[data-v-24441f9e]{background:var(--surface2);border-color:var(--border);color:var(--text)}.tab-btn[data-v-24441f9e]:hover:not(.active){color:var(--text)}.btn-logout[data-v-24441f9e]{font-size:.73rem;padding:.28rem .6rem;background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;transition:all .15s}.btn-logout[data-v-24441f9e]:hover{color:#ef4444;border-color:#ef4444}.tab-content[data-v-24441f9e]{padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.65rem;flex:1}.sec-title[data-v-24441f9e]{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.ch-row[data-v-24441f9e]{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:.65rem .8rem;display:flex;flex-direction:column;gap:.45rem}.ch-top[data-v-24441f9e]{display:flex;align-items:center;justify-content:space-between}.ch-id[data-v-24441f9e]{font-size:.83rem;font-weight:700;font-family:SF Mono,ui-monospace,monospace}.chk-label[data-v-24441f9e]{display:flex;align-items:center;gap:.35rem;font-size:.76rem;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.chk-label input[data-v-24441f9e]{cursor:pointer;accent-color:var(--blue)}.notify-row[data-v-24441f9e]{display:flex;align-items:center;gap:.65rem}.muted-sm[data-v-24441f9e]{font-size:.74rem;color:var(--text-muted)}.high-lbl span[data-v-24441f9e]{color:#22c55e}.low-lbl span[data-v-24441f9e]{color:var(--text-muted)}.label[data-v-24441f9e]{font-size:.8rem;font-weight:500;color:var(--text-muted)}.action-row[data-v-24441f9e]{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap;margin-top:.25rem}.btn-primary[data-v-24441f9e]{padding:.45rem .9rem;font-size:.84rem;font-weight:600;background:var(--blue);color:#fff;border:none;border-radius:7px;cursor:pointer;transition:opacity .15s;white-space:nowrap}.btn-primary[data-v-24441f9e]:hover:not(:disabled){opacity:.85}.btn-primary[data-v-24441f9e]:disabled{opacity:.4;cursor:not-allowed}.btn-secondary[data-v-24441f9e]{padding:.45rem .9rem;font-size:.84rem;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:7px;cursor:pointer;transition:background .15s;white-space:nowrap}.btn-secondary[data-v-24441f9e]:hover:not(:disabled){background:var(--border)}.btn-secondary[data-v-24441f9e]:disabled{opacity:.4;cursor:not-allowed}.msg[data-v-24441f9e]{font-size:.78rem}.msg.ok[data-v-24441f9e]{color:#22c55e}.msg.err[data-v-24441f9e]{color:#ef4444}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f172a;--surface: #1e293b;--surface2: #263348;--border: #334155;--text: #e2e8f0;--text-muted: #94a3b8;--high: #22c55e;--high-bg: rgba(34, 197, 94, .12);--low: #475569;--blue: #3b82f6;--purple: #a855f7;--radius: 10px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;-webkit-font-smoothing:antialiased}.auth-checking{display:flex;align-items:center;justify-content:center;min-height:100dvh}.checking-dot{width:10px;height:10px;border-radius:50%;background:var(--blue);animation:blink 1s ease-in-out infinite}.login-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:1rem}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:2.25rem 2rem;width:100%;max-width:340px;display:flex;flex-direction:column;gap:1.1rem}.login-brand{display:flex;align-items:center;gap:.65rem;font-size:1.15rem;font-weight:700;justify-content:center}.login-sub{text-align:center;font-size:.82rem;color:var(--text-muted)}.login-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:.65rem .9rem;color:var(--text);font-size:.95rem;outline:none;box-sizing:border-box;margin-bottom:.65rem;transition:border-color .15s}.login-input:focus{border-color:var(--blue)}.login-btn{width:100%;padding:.65rem;font-size:.95rem;font-weight:600;background:var(--blue);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.login-btn:hover:not(:disabled){opacity:.85}.login-btn:disabled{opacity:.4;cursor:not-allowed}.login-err{text-align:center;font-size:.8rem;color:#ef4444;margin-top:-.5rem}.connection-bar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:.65rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);gap:.75rem}.brand{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.95rem;flex-shrink:0}.status-group{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-muted);min-width:0}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--low);flex-shrink:0}.status-dot.connected{background:var(--high);box-shadow:0 0 6px var(--high)}.status-dot.connecting{background:#f59e0b;animation:blink 1s ease-in-out infinite}.status-dot.error{background:#ef4444}.status-label{white-space:nowrap}.error-msg{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#f87171;font-size:.75rem}.btn-sm{padding:.25rem .6rem;font-size:.75rem;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:6px;cursor:pointer;white-space:nowrap;transition:background .15s}.btn-sm:hover{background:var(--border)}.btn-notif{font-size:1rem;padding:.2rem .45rem}.btn-admin{font-size:.95rem;padding:.2rem .45rem}.btn-logout{color:#94a3b8}.btn-logout:hover{color:#ef4444;border-color:#ef4444}@keyframes blink{0%,to{opacity:1}50%{opacity:.2}}.main-content{padding:1.25rem 1rem 3rem;max-width:1280px;margin:0 auto}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 1rem;gap:.75rem;color:var(--text-muted)}.empty-icon{opacity:.5}.empty-title{font-size:1rem;font-weight:600}.empty-sub{font-size:.8rem}.section{margin-bottom:2rem}.section-title{display:flex;align-items:center;gap:.45rem;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.75rem}.section-dot{width:8px;height:8px;border-radius:50%}.output-dot{background:var(--blue)}.input-dot{background:var(--purple)}.section-count{background:var(--surface2);border-radius:999px;padding:.05rem .45rem;font-size:.7rem;color:var(--text-muted)}.dio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.65rem}.dio-card{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--border);border-radius:var(--radius);padding:.85rem .85rem .75rem;display:flex;flex-direction:column;gap:.35rem;transition:border-color .2s,box-shadow .2s}.dio-card.output{border-left-color:var(--blue)}.dio-card.input{border-left-color:var(--purple)}.dio-card.high{border-color:var(--high);border-left-color:var(--high);box-shadow:0 0 14px #22c55e24}.card-header{display:flex;align-items:center;justify-content:space-between}.channel-name{font-weight:700;font-size:.9rem;font-family:SF Mono,ui-monospace,monospace}.state-badge{font-size:.63rem;font-weight:700;padding:.15rem .4rem;border-radius:4px;letter-spacing:.04em;font-family:SF Mono,ui-monospace,monospace}.badge-high{background:var(--high-bg);color:var(--high)}.badge-low{background:var(--surface2);color:var(--text-muted)}.card-desc{font-size:.72rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.last-change{font-size:.68rem;color:var(--text-muted);opacity:.7}.card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.25rem}.timestamp{font-size:.68rem;color:var(--text-muted)}.btn-toggle{padding:.28rem .6rem;font-size:.7rem;font-weight:600;border-radius:6px;border:1px solid var(--border);cursor:pointer;background:var(--surface2);color:var(--text-muted);transition:all .15s;white-space:nowrap}.btn-toggle.active{background:var(--high-bg);border-color:var(--high);color:var(--high)}.btn-toggle:hover:not(:disabled){filter:brightness(1.2)}.btn-toggle:disabled{opacity:.4;cursor:not-allowed}.input-indicator{display:flex;align-items:center;gap:.3rem;font-size:.7rem;color:var(--text-muted)}.input-led{width:7px;height:7px;border-radius:50%}.led-high{background:var(--high);box-shadow:0 0 5px var(--high)}.led-low{background:var(--low)}@media(max-width:480px){.dio-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}
