:root{color-scheme:light;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.5}body{margin:0;background:#fff;color:#1a1a1a;display:flex;align-items:flex-start;justify-content:center;min-height:100vh;padding:1rem}main{max-width:520px;width:100%}body.editing{padding-top:.4rem;padding-bottom:60vh}body.editing h1,body.editing .subtitle{display:none}#mqttPassword{scroll-margin-top:.5rem}h1{margin:0 0 .25rem;font-size:1.75rem}.subtitle{margin:0 0 1rem;color:#666}fieldset{border:1px solid #e0e0e0;border-radius:6px;padding:1rem;margin:0 0 1rem}.card{border:1px solid #e0e0e0;border-radius:8px;padding:1rem;margin:0}legend{padding:0 .5rem;color:#666;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}details.defaults{margin:0 0 1rem}details.defaults>summary{cursor:pointer;padding:.5rem .75rem;color:#666;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;border:1px solid #e0e0e0;border-radius:6px;list-style:none}details.defaults>summary::-webkit-details-marker{display:none}details.defaults>summary:before{content:"▸ ";display:inline-block;transition:transform .15s}details.defaults[open]>summary:before{transform:rotate(90deg)}details.defaults[open]>summary{border-radius:6px 6px 0 0;border-bottom:none}details.defaults[open]>fieldset{border-radius:0 0 6px 6px;margin-top:0}label{display:block;margin:.5rem 0 .25rem;font-size:.85rem;color:#444}.card>label:first-child{margin-top:0}input,textarea{width:100%;background:#fff;color:#1a1a1a;border:1px solid #c8c8c8;border-radius:4px;padding:.5rem .75rem;font-family:ui-monospace,SF Mono,monospace;font-size:.95rem;box-sizing:border-box}input::placeholder,textarea::placeholder{color:#9a9a9a;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}input:focus,textarea:focus{outline:none;border-color:#2f6fd0;box-shadow:0 0 0 2px #2f6fd02e}textarea{resize:none;overflow:hidden;min-height:4em}.actions{display:flex;gap:.6rem;margin:.6rem 0 0}.actions #connect-button{flex:2}.actions #clear-cache-button{flex:1;font-size:.9rem}button{flex:1;padding:.6rem 1rem;border-radius:4px;border:none;background:#2f6fd0;color:#fff;font-size:1rem;font-weight:500;cursor:pointer;min-height:42px}button:active{transform:translateY(1px)}button:disabled{background:#d4d4d4;color:#f4f4f4;cursor:default}button.secondary{background:transparent;color:#666;border:1px solid #c8c8c8}button.secondary:disabled{background:transparent;color:silver;border-color:#e8e8e8;cursor:default}.status{margin-top:.6rem;padding:.6rem .85rem;border-radius:4px;font-size:.95rem;min-height:1.5em}.status:empty{display:none}.status--info{background:#eef2fb;color:#2b4a86}.status--success{background:#e6f5ec;color:#157a45}.status--error{background:#fcebeb;color:#dc2626}.field-with-toggle{position:relative}.field-with-toggle>input,.field-with-toggle>textarea{width:100%;padding-right:2.75rem}button.eye-icon{position:absolute;right:.35rem;width:2rem;height:2rem;min-height:0;padding:0;background:transparent;color:#777;border:1px solid transparent;border-radius:4px;font-size:1rem;line-height:1;cursor:pointer}.field-with-toggle>input+button.eye-icon{top:50%;transform:translateY(-50%)}.field-with-toggle>textarea+button.eye-icon{top:.35rem}button.eye-icon:hover{background:#0000000d;border-color:#d8d8d8}button.eye-icon[data-state=visible]{color:#157a45}.is-text-masked{-webkit-text-security:disc}input[aria-invalid=true],textarea[aria-invalid=true]{border-color:#dc2626}input[aria-invalid=true]:focus,textarea[aria-invalid=true]:focus{border-color:#dc2626;box-shadow:0 0 0 2px #dc262633}.field-error{margin-top:.6rem;padding:.4rem .7rem;background:#fcebeb;border-left:3px solid #dc2626;border-radius:0 4px 4px 0;color:#dc2626;font-size:.85rem;line-height:1.3}.indicator{margin-top:.6rem}.indicator:empty{display:none}.indicator-row{padding:.65rem 0;border-bottom:1px solid #ececec}.indicator-row:last-child{border-bottom:none}[data-testid=stage-1],[data-testid=stage-2],[data-testid=stage-3]{font-size:.95rem;font-weight:500}[data-testid^=stage-][data-status=pending]{color:#888}[data-testid^=stage-][data-status=success]{color:#157a45}[data-testid^=stage-][data-status=warning]{color:#9a6700}[data-testid^=stage-][data-status=failure]{color:#dc2626}[data-testid^=stage-][data-status=skipped]{color:#999;font-style:italic}[data-testid$=-hint]{margin-top:.25rem;font-size:.85rem;color:#666;line-height:1.4}[data-testid$=-hint]:empty{display:none}.indicator-decorations{padding:.5rem 0;font-size:.85rem;color:#555}.indicator-decorations:empty{display:none}.indicator-decorations [data-testid^=path-]{padding:.5rem .75rem;margin:.35rem 0;background:#eef2fb;border-left:3px solid #2f6fd0;border-radius:0 4px 4px 0;line-height:1.4}.indicator-decorations [data-testid=path-B-action]{display:inline-block;margin:.5rem 0;padding:.4rem .75rem;background:transparent;border:1px solid #2f6fd0;border-radius:4px;color:#2f6fd0;font-size:.85rem;cursor:pointer}.indicator-decorations [data-testid=ops-escalation]{padding:.5rem .75rem;margin-top:.5rem;background:#fcebeb;border:1px solid #f2c9c6;border-radius:4px;color:#dc2626;font-size:.85rem;text-align:center}.indicator-decorations [data-testid=positive-signal]{display:inline-block;padding:.25rem .6rem;background:#e6f5ec;border-radius:4px;color:#157a45;font-size:.85rem;font-weight:500}.indicator-decorations [data-testid=osd-age]{display:inline-block;padding:.2rem .5rem;background:#eef2fb;border-radius:4px;color:#2b4a86;font-size:.8rem;font-family:ui-monospace,SF Mono,monospace}.indicator-recovery-log{display:none}[data-testid=recheck-button]{flex:none;display:block;margin:.75rem 0 .25rem auto;padding:.5rem 1rem;min-height:0;background:transparent;border:1px solid #c8c8c8;color:#555;font-size:.85rem}.indicator-row,.indicator-decorations,[data-testid=recheck-button]{display:none}.status-line{padding:.55rem .85rem;border-radius:4px;font-size:1rem;font-weight:500;margin:0}.status-line:empty{display:none}.status-line--progress{background:#eef2fb;color:#2b4a86}.status-line--good{background:#e6f5ec;color:#157a45}.status-line--warning{background:#fdf6d8;color:#7a5c00}.status-line--error{background:#fcebeb;color:#dc2626}button.primary-action{display:block;width:100%;margin:.25rem 0 .5rem}.status-code{margin:.1rem 0 .4rem;font-family:ui-monospace,SF Mono,monospace;font-size:.8rem;color:#6a6a6a}.status-code:empty{display:none}.status-ways{margin:0 0 .6rem;padding-left:1.2rem;font-size:.9rem;color:#333;line-height:1.5}.status-ways:empty{display:none}.status-ways>li{margin:.15rem 0}
