*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{overflow-x:hidden}body{color:#1a1a1a;background:#f1f3f7;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;transition:background .2s,color .2s}.dark body{color:#e2e8f0;background:#0f1117}.dark .app{background:#0f1117!important}.dark header{background:#1a1d27!important;border-color:#2d3148!important;box-shadow:0 1px 6px #00000080!important}.dark main{background:#0f1117!important}.dark .card,.dark .panel,.dark .table-wrap{background:#1a1d27!important;border-color:#2d3148!important}.dark h1,.dark .sensor-name,.dark .card-title,.dark .did-value{color:#e2e8f0!important}.dark h2,.dark label,.dark .slider-val,.dark .did-label{color:#94a3b8!important}.dark .clamp{color:#64748b!important}.dark input[type=text],.dark input[type=number],.dark input[type=email],.dark input[type=password],.dark select{color:#e2e8f0!important;background:#0f1117!important;border-color:#2d3148!important}.dark input[readonly]{color:#64748b!important;background:#1e2130!important}.dark textarea{color:#4ade80!important;background:#0d200f!important;border-color:#166534!important}.dark input::placeholder{color:#475569!important}.dark .divider{background:#2d3148!important}.dark thead{background:#1e2130!important;border-color:#2d3148!important}.dark th{color:#64748b!important}.dark td{border-color:#2d3148!important}.dark tr:hover td{background:#1e2130!important}.dark .icon-cell{background:#2d3148!important}.dark .badge.blue{color:#93c5fd!important;background:#1e3a5f!important}.dark .badge.green{color:#4ade80!important;background:#14532d!important}.dark .logout-btn{color:#94a3b8!important;border-color:#2d3148!important}.dark .logout-btn:hover{color:#e2e8f0!important;border-color:#64748b!important}.dark .new-btn{color:#111827!important;background:#e2e8f0!important}.dark .back-btn{color:#94a3b8!important;border-color:#2d3148!important}.dark .back-btn:hover{color:#818cf8!important;background:#1e1b4b!important;border-color:#6366f1!important}.dark .edit-btn:hover{color:#818cf8!important;background:#1e1b4b!important}.dark .delete-btn:hover{color:#f87171!important;background:#450a0a!important}.dark .btn.secondary{color:#94a3b8!important;background:#2d3148!important;border-color:#374151!important}.dark .user-name{color:#94a3b8!important}.dark .user-info:hover{background:#2d3148!important}.dark .settings-dropdown{background:#1a1d27!important;border-color:#2d3148!important;box-shadow:0 8px 24px #00000080!important}.dark .settings-title{color:#64748b!important}.dark .settings-item{color:#94a3b8!important}.dark .settings-item:hover{background:#2d3148!important}.dark .settings-item.danger{color:#f87171!important}.dark .status-badge{color:#94a3b8!important;background:#2d3148!important;border-color:#374151!important}.dark .status-badge.connected{color:#4ade80!important;background:#14532d55!important;border-color:#166534!important}.dark .serial-bar{background:#1e2130!important;border-color:#2d3148!important}.dark .serial-status{color:#64748b!important}.dark .serial-status.connected{color:#4ade80!important}.dark .slider{background:#2d3148!important}.dark .topic-preview{color:#818cf8!important;background:#1e1b4b!important;border-color:#312e81!important}.dark .btn-copy{color:#94a3b8!important;border-color:#2d3148!important}.dark .did-modal{background:#1a1d27!important;border-color:#2d3148!important}.dark .did-close{color:#94a3b8!important;background:#2d3148!important;border-color:#374151!important}.dark .empty-state{color:#4b5563!important}.dark .page{background:linear-gradient(135deg,#1e1b4b 0%,#0f2d1f 100%)!important}.dark .save-btn{background:#374151!important}.dark .save-error{background:#450a0a!important;border-color:#7f1d1d!important}.dark .item .label{color:#e2e8f0!important}.dark .item .desc{color:#64748b!important}.dark .item.selected{background:#1e1b4b!important;border-color:#6d28d9!important}.dark .item.selected .label{color:#c4b5fd!important}.dark .panel .header{background:#1e2130!important;border-color:#2d3148!important}.dark .panel .title{color:#94a3b8!important}.dark .card-header{background:#1e2130!important;border-color:#2d3148!important}.dark .picker-label{color:#94a3b8!important}.dark .param-row{background:#1a1730!important;border-color:#2d1f5e!important}.app.svelte-12qhfyh{background:#f9fafb;flex-direction:column;min-height:100vh;display:flex}header.svelte-12qhfyh{background:#fff;border-bottom:1px solid #e4e7ec;flex-shrink:0;justify-content:space-between;align-items:center;padding:.875rem 1.75rem;display:flex;box-shadow:0 1px 4px #0000000f}.left.svelte-12qhfyh{align-items:center;gap:.6rem;display:flex}h1.svelte-12qhfyh{color:#111827;letter-spacing:-.01em;font-size:1.125rem;font-weight:700}.theme-btn.svelte-12qhfyh{color:#6b7280;cursor:pointer;background:#f9fafb;border:1.5px solid #e4e7ec;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:border-color .15s,color .15s;display:flex}.theme-btn.svelte-12qhfyh:hover{color:#6366f1;border-color:#6366f1}.back-btn.svelte-12qhfyh{color:#374151;border:1.5px solid #e4e7ec;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;text-decoration:none;transition:border-color .15s,background .15s,color .15s;display:inline-flex}.back-btn.svelte-12qhfyh:hover{color:#6366f1;background:#f5f3ff;border-color:#6366f1}.actions.svelte-12qhfyh{align-items:center;gap:.75rem;display:flex}.user-info-wrap.svelte-12qhfyh{position:relative}.user-info.svelte-12qhfyh{cursor:pointer;background:0 0;border:none;border-radius:7px;align-items:center;gap:.5rem;margin-right:.25rem;padding:.3rem .5rem;transition:background .15s;display:flex}.user-info.svelte-12qhfyh:hover{background:#f3f4f6}.user-info.svelte-12qhfyh svg:where(.svelte-12qhfyh){color:#9ca3af;flex-shrink:0}.avatar.svelte-12qhfyh{object-fit:cover;border:2px solid #e4e7ec;border-radius:50%;width:28px;height:28px}.user-name.svelte-12qhfyh{color:#374151;font-size:.875rem;font-weight:500}.settings-backdrop.svelte-12qhfyh{z-index:10;position:fixed;inset:0}.settings-dropdown.svelte-12qhfyh{z-index:11;background:#fff;border:1px solid #e4e7ec;border-radius:10px;flex-direction:column;min-width:220px;padding:.35rem;display:flex;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 8px 24px #0000001f}.settings-title.svelte-12qhfyh{color:#9ca3af;text-transform:uppercase;letter-spacing:.06em;padding:.4rem .6rem .25rem;font-size:.7rem;font-weight:600}.settings-item.svelte-12qhfyh{cursor:pointer;text-align:left;color:#374151;background:0 0;border:none;border-radius:7px;align-items:center;gap:.5rem;width:100%;padding:.55rem .6rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex}.settings-item.svelte-12qhfyh:hover{background:#f3f4f6}.settings-item.danger.svelte-12qhfyh{color:#dc2626}.settings-item.danger.svelte-12qhfyh:hover{background:#fee2e2}.delete-confirm.svelte-12qhfyh{flex-direction:column;gap:.6rem;padding:.4rem .6rem .5rem;display:flex}.delete-confirm.svelte-12qhfyh p:where(.svelte-12qhfyh){color:#6b7280;font-size:.8rem;line-height:1.45}.delete-error.svelte-12qhfyh{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:.4rem .5rem;color:#dc2626!important;font-size:.78rem!important}.confirm-actions.svelte-12qhfyh{gap:.4rem;display:flex}.confirm-cancel.svelte-12qhfyh{color:#374151;cursor:pointer;background:#f3f4f6;border:none;border-radius:6px;flex:1;padding:.45rem;font-size:.8rem;font-weight:600;transition:background .12s}.confirm-cancel.svelte-12qhfyh:hover:not(:disabled){background:#e5e7eb}.confirm-cancel.svelte-12qhfyh:disabled{opacity:.5;cursor:not-allowed}.confirm-delete.svelte-12qhfyh{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:.35rem;padding:.45rem;font-size:.8rem;font-weight:600;transition:background .12s;display:flex}.confirm-delete.svelte-12qhfyh:hover:not(:disabled){background:#b91c1c}.confirm-delete.svelte-12qhfyh:disabled{opacity:.6;cursor:not-allowed}.mini-spinner.svelte-12qhfyh{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:11px;height:11px;animation:.7s linear infinite svelte-12qhfyh-spin;display:block}.fauxbit-btn.svelte-12qhfyh,.device-id-btn.svelte-12qhfyh{color:#6366f1;cursor:pointer;background:0 0;border:1.5px solid #c7d2fe;border-radius:6px;align-items:center;gap:.4rem;padding:.45rem .9rem;font-size:.875rem;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s;display:inline-flex}.fauxbit-btn.svelte-12qhfyh:hover,.device-id-btn.svelte-12qhfyh:hover:not(:disabled){background:#eef2ff;border-color:#a5b4fc}.device-id-btn.svelte-12qhfyh:disabled{opacity:.55;cursor:not-allowed}.new-btn.svelte-12qhfyh{color:#fff;background:#111827;border:none;border-radius:6px;align-items:center;gap:.4rem;padding:.45rem 1rem;font-size:.875rem;font-weight:600;text-decoration:none;transition:background .15s;display:inline-flex}.new-btn.svelte-12qhfyh:hover{background:#374151}.logout-btn.svelte-12qhfyh{color:#6b7280;cursor:pointer;background:0 0;border:1.5px solid #e4e7ec;border-radius:6px;align-items:center;gap:.4rem;padding:.45rem .9rem;font-size:.875rem;font-weight:500;transition:border-color .15s,color .15s;display:inline-flex}.logout-btn.svelte-12qhfyh:hover{color:#374151;border-color:#9ca3af}.did-spinner.svelte-12qhfyh{border:2px solid #c7d2fe;border-top-color:#6366f1;border-radius:50%;width:13px;height:13px;animation:.7s linear infinite svelte-12qhfyh-spin;display:block}.did-backdrop.svelte-12qhfyh{z-index:200;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.did-modal.svelte-12qhfyh{background:#fff;border:1px solid #e4e7ec;border-radius:14px;flex-direction:column;align-items:center;gap:1rem;width:90%;max-width:320px;padding:2rem;display:flex;box-shadow:0 16px 48px #00000026}.did-label.svelte-12qhfyh{color:#6b7280;text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:.72rem;font-weight:600}.did-qr.svelte-12qhfyh{border-radius:8px;width:200px;height:200px}.did-value.svelte-12qhfyh{color:#111827;letter-spacing:.12em;text-align:center;margin:0;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:1.5rem;font-weight:700}.did-close.svelte-12qhfyh{color:#374151;cursor:pointer;background:#f3f4f6;border:1.5px solid #e4e7ec;border-radius:8px;width:100%;padding:.55rem;font-size:.875rem;font-weight:600;transition:background .15s}.did-close.svelte-12qhfyh:hover{background:#e5e7eb}.did-toast.svelte-12qhfyh{color:#dc2626;z-index:200;cursor:pointer;white-space:nowrap;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:.65rem 1.25rem;font-size:.875rem;font-weight:500;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0000001a}.splash.svelte-12qhfyh{justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner.svelte-12qhfyh{border:3px solid #e4e7ec;border-top-color:#6366f1;border-radius:50%;width:32px;height:32px;animation:.7s linear infinite svelte-12qhfyh-spin;display:block}@keyframes svelte-12qhfyh-spin{to{transform:rotate(360deg)}}@media (width<=640px){header.svelte-12qhfyh{padding:.75rem 1rem}h1.svelte-12qhfyh,.user-name.svelte-12qhfyh{display:none}.user-info.svelte-12qhfyh{margin-right:0}.btn-label.svelte-12qhfyh{display:none}.actions.svelte-12qhfyh{gap:.4rem}.new-btn.svelte-12qhfyh,.logout-btn.svelte-12qhfyh,.fauxbit-btn.svelte-12qhfyh,.device-id-btn.svelte-12qhfyh{padding:.45rem .6rem}}
