:root{--speaq-deep:#0a0e1a;--speaq-gold:#d4a853;--speaq-teal:#2dd4bf;--speaq-off-white:#e8e9ee;--speaq-error:#ef4444;--speaq-warn:#f59e0b;--radius:8px;--font-display:"Playfair Display", Georgia, serif;--font-body:"Manrope", -apple-system, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "Courier New", monospace;--bg:var(--speaq-deep);--fg:var(--speaq-off-white);--fg-muted:#e8e9ee99;--fg-soft:#e8e9eeb3;--border:#33415540;--input-bg:#e8e9ee0a;--row-bg:#e8e9ee08;--modal-bg:#131726;--teal-tint:#2dd4bf0f;--teal-tint-strong:#2dd4bf14;--teal-tint-border:#2dd4bf38;--gold-tint:#d4a8531f;--shadow-card:0 4px 24px #0000002e;--backdrop:#0a0e1ad9}[data-theme=light]{--bg:var(--speaq-off-white);--fg:var(--speaq-deep);--fg-muted:#0a0e1a8c;--fg-soft:#0a0e1ab3;--border:#0a0e1a1f;--input-bg:#ffffffd9;--row-bg:#ffffffb3;--modal-bg:#fff;--teal-tint:#14a09114;--teal-tint-strong:#14a0911f;--teal-tint-border:#14a09152;--gold-tint:#b4822824;--shadow-card:0 4px 24px #0a0e1a14;--backdrop:#0a0e1a80}*{box-sizing:border-box}html,body{font-family:var(--font-body);background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;margin:0;padding:0;transition:background-color .2s,color .2s}#root{flex-direction:column;min-height:100vh;display:flex}.app{width:100%;max-width:720px;padding:24px;padding-top:calc(env(safe-area-inset-top,0px) + 24px);padding-bottom:calc(env(safe-area-inset-bottom,0px) + 24px);flex-direction:column;flex:1;margin:0 auto;display:flex}.brand{color:var(--fg);justify-content:center;align-items:center;gap:16px;min-height:72px;margin-bottom:20px;display:flex;position:relative}.brand svg{flex:0 auto;max-width:100%;height:auto;display:block}.brand .theme-toggle{position:absolute;top:50%;right:0;transform:translateY(-50%)}.theme-toggle{background:var(--input-bg);border:1px solid var(--border);width:40px;height:40px;color:var(--fg);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:background-color .15s,border-color .15s,color .15s;display:inline-flex}.theme-toggle:hover{color:var(--speaq-gold);border-color:var(--speaq-gold)}.theme-toggle svg{width:20px;height:20px;display:block}.health-strip{background:var(--teal-tint-strong);border:1px solid var(--teal-tint-border);border-radius:999px;align-self:flex-start;align-items:center;gap:10px;margin-top:4px;margin-bottom:12px;padding:8px 14px;font-size:12px;font-weight:600;display:flex}.health-strip-loading{background:var(--gold-tint);border-color:#d4a85352}.health-strip-error{background:#ef444414;border-color:#ef44444d}.health-dot{background:var(--speaq-teal);border-radius:50%;width:8px;height:8px;animation:2s infinite health-pulse;box-shadow:0 0 #2dd4bfb3}.health-dot-pending{background:var(--speaq-gold);animation:none}.health-dot-error{background:var(--speaq-error);animation:none}.health-dot-ok{background:var(--speaq-teal)}@keyframes health-pulse{0%{box-shadow:0 0 #2dd4bfb3}70%{box-shadow:0 0 0 8px #2dd4bf00}to{box-shadow:0 0 #2dd4bf00}}.health-label{color:var(--fg)}.health-detail{color:var(--fg-soft);font-weight:500}.health-latency{color:var(--speaq-gold);font-family:var(--font-mono);margin-left:auto}.tab-bar{border-bottom:1px solid var(--border);margin-bottom:24px;display:flex}.tab-button{color:var(--fg);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-body);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:14px 8px;transition:color .15s,border-color .15s}.tab-button[data-active=true]{color:var(--speaq-gold);border-bottom-color:var(--speaq-gold)}.tab-button:hover:not([data-active=true]){color:var(--speaq-teal)}.form-section{flex-direction:column;gap:4px;margin-bottom:16px;display:flex}.label{opacity:.85;margin-top:12px;margin-bottom:4px;font-size:12px;font-weight:600}.input,.textarea,.select{border:1px solid var(--border);border-radius:var(--radius);background:var(--input-bg);width:100%;color:var(--fg);font-size:16px;font-family:var(--font-body);padding:12px 14px;transition:border-color .15s,background-color .15s}.input:focus,.textarea:focus,.select:focus{border-color:var(--speaq-gold);outline:none}.input::placeholder{color:var(--fg-muted)}.textarea{resize:vertical;min-height:80px}.btn{background:var(--speaq-gold);color:var(--speaq-deep);border-radius:var(--radius);letter-spacing:.5px;cursor:pointer;font-size:14px;font-weight:700;font-family:var(--font-body);text-align:center;border:none;margin-top:16px;padding:14px 24px;transition:opacity .15s,transform 50ms;display:inline-block}.btn:hover:not(:disabled){opacity:.9}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-block{width:100%;display:block}.btn-secondary{color:var(--fg);border:1px solid var(--border);background:0 0}.btn-danger{background:var(--speaq-error);color:#fff}.btn-small{margin-top:0;padding:8px 14px;font-size:13px}.h1{font-family:var(--font-display);color:var(--fg);margin:0 0 8px;font-size:28px;font-weight:700}.h2{font-family:var(--font-display);color:var(--fg);margin:0 0 12px;font-size:22px;font-weight:700}.muted{color:var(--fg-soft);font-size:14px;line-height:1.5}.error-text{color:var(--speaq-error);margin-top:8px;font-size:13px}.mono{font-family:var(--font-mono);word-break:break-all;font-size:12px;line-height:1.6}.did-box{background:var(--teal-tint);border:1px solid var(--teal-tint-border);border-radius:var(--radius);margin-bottom:12px;padding:12px 14px}.did-box .label{opacity:.7;margin:0 0 4px;font-size:11px}.did-box .mono{color:var(--speaq-teal);font-size:12px}.vault-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.vault-toolbar .input{flex:200px;min-width:0}.vault-toolbar .select{flex:none;max-width:160px}.vault-list{flex-direction:column;gap:8px;display:flex}.entry-row{background:var(--row-bg);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:12px;padding:14px 16px;display:flex}.entry-info{flex:1;min-width:0}.entry-title{color:var(--fg);font-size:16px;font-weight:600}.entry-sub{color:var(--fg-muted);margin-top:2px;font-size:13px}.entry-secret{font-family:var(--font-mono);color:var(--speaq-teal);margin-top:4px;font-size:13px}.entry-secret button{border:1px solid var(--teal-tint-border);color:var(--speaq-teal);cursor:pointer;background:0 0;border-radius:4px;margin-left:6px;padding:2px 8px;font-size:11px}.entry-tags{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.tag-chip{background:var(--gold-tint);color:var(--speaq-gold);border-radius:999px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.entry-actions{gap:4px;display:flex}.icon-btn{color:var(--fg-muted);cursor:pointer;font-size:13px;font-family:var(--font-body);background:0 0;border:none;border-radius:4px;padding:6px 8px}.icon-btn:hover{background:var(--input-bg);color:var(--fg)}.icon-btn.danger:hover{color:var(--speaq-error)}.modal-backdrop{background:var(--backdrop);z-index:100;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--modal-bg);border:1px solid var(--border);width:100%;max-width:480px;max-height:90vh;box-shadow:var(--shadow-card);border-radius:12px;padding:24px;overflow-y:auto}.totp-row{background:var(--row-bg);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.totp-info{flex:1;min-width:0}.totp-code{font-family:var(--font-mono);color:var(--speaq-gold);letter-spacing:2px;font-size:24px;font-weight:600}.totp-progress{width:32px;height:32px;margin-left:12px;position:relative}.totp-progress svg{transform:rotate(-90deg)}.totp-progress circle{fill:none;stroke-width:3px}.totp-progress .bg{stroke:var(--border)}.totp-progress .fg{stroke:var(--speaq-teal);transition:stroke-dashoffset 1s linear}.lang-switch{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.lang-pill{text-transform:uppercase;color:var(--fg-muted);border:1px solid var(--border);cursor:pointer;font-size:11px;font-family:var(--font-body);letter-spacing:.5px;background:0 0;border-radius:999px;padding:4px 10px;font-weight:600}.lang-pill[data-active=true]{background:var(--speaq-gold);color:var(--speaq-deep);border-color:var(--speaq-gold)}.settings-list{flex-direction:column;gap:12px;display:flex}.settings-row{background:var(--row-bg);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.settings-row .label-row{flex-direction:column;gap:2px;display:flex}.settings-row .label-row .title{color:var(--fg);font-size:14px;font-weight:600}.settings-row .label-row .sub{color:var(--fg-muted);font-size:12px}.toggle{background:var(--border);cursor:pointer;border:none;border-radius:999px;flex-shrink:0;width:44px;height:24px;position:relative}.toggle:before{content:"";background:var(--bg);border-radius:50%;width:20px;height:20px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #0003}.toggle[data-on=true]{background:var(--speaq-teal)}.toggle[data-on=true]:before{transform:translate(20px)}@media (width<=480px){.app{padding:16px;padding-top:max(env(safe-area-inset-top,0px) + 16px, 56px);padding-bottom:max(env(safe-area-inset-bottom,0px) + 8px, 16px)}.brand-name{font-size:28px}.vault-toolbar .select{flex:100%;max-width:none}.brand svg{max-width:75%}.brand .theme-toggle{width:36px;height:36px}}.login-idle,.login-error,.login-signing,.login-approved,.login-denied,.login-consent{flex-direction:column;gap:.65rem;display:flex}.login-actions{flex-direction:column;gap:.5rem;margin-top:.5rem;display:flex}.btn-secondary{border:1px solid var(--border,#78829159);color:var(--fg);background:0 0}.btn-secondary:hover{background:var(--card,#ffffff0a)}.did-box.ok{background:#2dd4bf14;border-color:#2dd4bf73}.did-box.warn{background:#f4ad4914;border-color:#f4ad4966}.scanner{flex-direction:column;gap:.6rem;margin:.5rem 0 1rem;display:flex}.scanner-stage{aspect-ratio:1;background:#000;border-radius:12px;width:100%;max-width:360px;margin:0 auto;position:relative;overflow:hidden}.scanner-video{object-fit:cover;width:100%;height:100%;display:block}.scanner-overlay{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.scanner-target{border:2px solid #d4a853d9;border-radius:12px;width:70%;height:70%;box-shadow:0 0 0 9999px #00000059}.credentials-section{margin-bottom:28px}.credentials-list{flex-direction:column;gap:12px;margin-top:12px;display:flex}.credential-card{border:1px solid var(--speaq-gold);background:var(--gold-tint);border-radius:12px;flex-direction:column;gap:8px;padding:16px;display:flex}.credential-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:12px;display:flex}.credential-claim{font-family:var(--font-mono);color:var(--speaq-gold);font-weight:700}.credential-type{text-transform:uppercase;letter-spacing:.06em;color:var(--fg-soft);font-size:11px;font-weight:600}.credential-issuer{flex-direction:column;gap:2px;font-size:12px;display:flex}.credential-issuer .label{text-transform:uppercase;letter-spacing:.05em;color:var(--fg-soft);font-size:11px}.credential-subject{flex-direction:column;gap:4px;margin:4px 0 0;display:flex}.credential-subject .kv-row{border-bottom:1px dashed var(--border);justify-content:space-between;gap:12px;padding-bottom:4px;font-size:13px;display:flex}.credential-subject dt{color:var(--fg-soft);font-weight:600}.credential-subject dd{text-align:right;color:var(--fg);margin:0}.btn-link{color:var(--speaq-teal);cursor:pointer;background:0 0;border:none;align-self:flex-start;padding:0;font-family:inherit;font-size:13px;text-decoration:underline}.credential-proof{background:var(--input-bg);font-size:11px;font-family:var(--font-mono);color:var(--fg-soft);white-space:pre-wrap;word-break:break-word;border-radius:8px;margin:0;padding:10px;overflow-x:auto}.manifest-badge{border:1px solid;border-radius:10px;flex-direction:column;gap:4px;margin:0;padding:12px 14px;font-size:.85rem;display:flex}.manifest-badge strong{letter-spacing:.04em}.manifest-badge.pending{border-color:var(--border);background:var(--input-bg);color:var(--fg-soft)}.manifest-badge.ok{color:var(--speaq-teal);background:#2dd4bf14;border-color:#2dd4bf80}.manifest-badge.warn{color:var(--speaq-warn);background:#f59e0b14;border-color:#f59e0b80}.manifest-badge.bad{color:var(--speaq-error);background:#ef44441a;border-color:#ef444499;font-weight:600}.manifest-badge.bad code,.manifest-badge.warn code{background:0 0;padding:0 4px}
