*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=dark]{--bg:#000;--bg-surface:#141414;--bg-surface-alt:#0e0e0e;--bg-elevated:#1a1a1a;--bg-hover:#ffffff0f;--bg-hover-strong:#ffffff1a;--bg-input:#ffffff0a;--bg-overlay:#00000080;--bg-loading-overlay:#141414e6;--border:#ffffff14;--border-hover:#ffffff26;--border-strong:#ffffff40;--border-input-focus:#6e8efb66;--text:#e0e0e0;--text-secondary:#ccc;--text-tertiary:#aaa;--text-muted:#888;--text-faint:#666;--text-ghost:#555;--text-placeholder:#333;--text-dimmer:#444;--text-label:#777;--accent:#6e8efb;--accent-bg:#6e8efb26;--accent-border:#6e8efb4d;--accent-text:#9db5ff;--accent-desc:#8a9ec7;--green:#4ade80;--green-bg:#4ade8026;--green-border:#4ade804d;--green-bg-subtle:#4ade8014;--red:#ef4444;--red-bg:#ef44441a;--red-border:#ef444433;--red-text:#ff6b6b;--red-hover:#ff8a8a;--red-hover-bg:#ff505014;--yellow:#facc15;--yellow-text:#f59e0b;--yellow-bg:#f59e0b1f;--blue-bg:#3b82f614;--blue-text:#60a5fa;--blue-border:#3b82f626;--blue-hover-bg:#3b82f624;--blue-hover-border:#3b82f640;--spinner-track:#ffffff1a;--pin-dot:#e5e5e5;--pin-step-border:#ffffff1f}[data-theme=light]{--bg:#fff;--bg-surface:#f2f2f2;--bg-surface-alt:#f7f7f7;--bg-elevated:#e8e8e8;--bg-hover:#0000000a;--bg-hover-strong:#00000014;--bg-input:#00000008;--bg-overlay:#0000004d;--bg-loading-overlay:#f0f0f0eb;--border:#0000001a;--border-hover:#0003;--border-strong:#0000004d;--border-input-focus:#4a6ae880;--text:#1a1a1a;--text-secondary:#333;--text-tertiary:#555;--text-muted:#777;--text-faint:#999;--text-ghost:#aaa;--text-placeholder:#bbb;--text-dimmer:#aaa;--text-label:#888;--accent:#4a6ae8;--accent-bg:#4a6ae81a;--accent-border:#4a6ae84d;--accent-text:#4a6ae8;--accent-desc:#5a78c0;--green:#16a34a;--green-bg:#16a34a1f;--green-border:#16a34a4d;--green-bg-subtle:#16a34a0f;--red:#dc2626;--red-bg:#dc262614;--red-border:#dc262633;--red-text:#dc2626;--red-hover:#b91c1c;--red-hover-bg:#dc26260f;--yellow:#ca8a04;--yellow-text:#b45309;--yellow-bg:#b453091a;--blue-bg:#3b82f60f;--blue-text:#2563eb;--blue-border:#3b82f626;--blue-hover-bg:#3b82f61a;--blue-hover-border:#3b82f640;--spinner-track:#0000001a;--pin-dot:#333;--pin-step-border:#0000001f}html,body,#root{width:100%;height:100%;overflow:hidden}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.voice-orb-area{flex-direction:column;align-items:center;gap:0;width:100%;max-width:840px;margin:0 auto;display:flex;position:absolute;top:36%;left:0;right:0;transform:translateY(-50%)}.voice-orb-wrapper{aspect-ratio:1;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;outline:none;justify-content:center;align-items:center;width:min(840px,100%);display:flex;position:relative;transform:scale(1.3)}.voice-orb-canvas{width:100%;height:100%;position:absolute;top:0;left:0}.voice-orb-hit-target{cursor:pointer;z-index:1;border-radius:50%;justify-content:center;align-items:center;width:45%;height:45%;display:flex;position:absolute}.voice-orb-label{z-index:1;letter-spacing:.5px;text-transform:uppercase;color:var(--text-muted);pointer-events:none;font-size:14px;font-weight:500;transition:color .3s;position:relative}.voice-orb-label.listening{color:var(--green)}.voice-orb-label.connecting{color:var(--yellow)}.voice-orb-label.paused{color:var(--text-muted);opacity:.7}.voice-orb-label.error{color:var(--red)}.voice-orb-status{color:var(--text-ghost);visibility:visible;height:20px;margin-top:-40px;font-size:13px}.transcript{top:calc(36% + 200px);bottom:calc(72px + env(safe-area-inset-bottom,0px));text-align:center;scrollbar-width:thin;scrollbar-color:#ffffff26 transparent;width:90%;max-width:600px;margin:0 auto;transition:bottom .15s ease-out;position:absolute;left:0;right:0;overflow-y:auto;-webkit-mask-image:linear-gradient(#0000 0%,#000 3%);mask-image:linear-gradient(#0000 0%,#000 3%)}.transcript::-webkit-scrollbar{width:4px}.transcript::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.transcript::-webkit-scrollbar-track{background:0 0}.transcript-line{color:var(--text-muted);word-wrap:break-word;overflow-wrap:break-word;margin-bottom:8px;padding:0 16px;font-size:14px;line-height:1.5}.transcript-line.user{color:var(--text-faint)}.transcript-line.assistant{color:var(--text-secondary)}.text-input-bar{bottom:calc(16px + env(safe-area-inset-bottom,0px));z-index:5;gap:8px;width:90%;max-width:560px;margin:0 auto;padding:12px 16px;transition:bottom .15s ease-out;display:flex;position:absolute;left:0;right:0}.text-input-bar input{background:var(--bg-hover);border:1px solid var(--border-hover);color:var(--text);border-radius:12px;outline:none;flex:1;padding:10px 16px;font-size:16px;transition:border-color .2s}.text-input-bar input::placeholder{color:var(--text-placeholder)}.text-input-bar input:focus{border-color:#4ade8080}.text-input-bar input:disabled{opacity:.4}.text-input-bar button{color:var(--green);cursor:pointer;white-space:nowrap;background:#4ade8040;border:1px solid #4ade8066;border-radius:12px;padding:10px 20px;font-size:14px;transition:all .2s}.text-input-bar button:hover:not(:disabled){background:#4ade8059;border-color:#4ade8099}.text-input-bar button:disabled{opacity:.5;cursor:not-allowed}.drawer-overlay{background:var(--bg-overlay);z-index:100;opacity:0;pointer-events:none;transition:opacity .3s;position:fixed;inset:0}.drawer-overlay.open{opacity:1;pointer-events:auto}.drawer{background:var(--bg-surface);border-left:1px solid var(--border);z-index:101;flex-direction:column;width:380px;max-width:90vw;height:100%;transition:transform .3s;display:flex;position:fixed;top:0;right:0;transform:translate(100%)}.drawer.open{transform:translate(0)}.drawer-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.drawer-header--minimal{border-bottom:none;justify-content:flex-end;padding:16px 20px 0}.drawer-header h2{color:var(--text);font-size:16px;font-weight:600}.drawer-close{color:var(--text-faint);cursor:pointer;background:0 0;border:none;padding:4px;font-size:20px}.drawer-close:hover{color:var(--text)}.drawer-body{flex-direction:column;flex:1;gap:20px;padding:24px;display:flex;overflow-y:auto}.drawer-footer{border-top:1px solid var(--border);padding:16px 24px}.drawer-footer p{color:var(--text-muted);font-size:12px;line-height:1.5}.settings-section{flex-direction:column;gap:10px;display:flex}.settings-section h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin:0;font-size:12px;font-weight:500}.settings-orb-name-input{border:1px solid var(--border);background:var(--bg-input);width:100%;color:var(--text);border-radius:8px;outline:none;padding:10px 12px;font-size:15px;transition:border-color .2s}.settings-orb-name-input:focus{border-color:var(--accent)}.settings-orb-name-input::placeholder{color:var(--text-placeholder)}.settings-orb-name-meta{justify-content:space-between;align-items:center;gap:8px;display:flex}.settings-orb-name-count{color:var(--text-faint);font-size:11px}.settings-orb-name-count.warning{color:var(--yellow-text)}.settings-orb-name-error{color:var(--red-text);font-size:11px}.settings-disabled-note{color:var(--text-faint);margin:0;font-size:11px;font-style:italic}.settings-btn-grid{flex-wrap:wrap;gap:6px;display:flex}.settings-grid-btn{border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-tertiary);cursor:pointer;border-radius:6px;padding:6px 12px;font-family:inherit;font-size:13px;transition:all .15s}.settings-grid-btn:hover:not(:disabled){border-color:var(--border-strong);color:var(--text)}.settings-grid-btn.active{border-color:var(--accent);background:var(--accent-bg);color:var(--accent-text)}.settings-grid-btn:disabled{opacity:.4;cursor:not-allowed}.settings-model-list{flex-direction:column;gap:6px;display:flex}.settings-model-btn{border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-tertiary);cursor:pointer;text-align:left;border-radius:8px;flex-direction:column;align-items:flex-start;padding:10px 12px;font-family:inherit;transition:all .15s;display:flex}.settings-model-btn:hover:not(:disabled){border-color:var(--border-strong);color:var(--text)}.settings-model-btn.active{border-color:var(--accent);background:var(--accent-bg);color:var(--accent-text)}.settings-model-btn:disabled{opacity:.4;cursor:not-allowed}.settings-model-name{font-size:13px;font-weight:600}.settings-model-desc{color:var(--text-faint);margin-top:2px;font-size:11px;line-height:1.4}.settings-model-btn.active .settings-model-desc{color:var(--accent-desc)}.settings-voice-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.settings-voice-grid-scroll{max-height:280px;overflow-y:auto}.settings-voice-btn{border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-tertiary);cursor:pointer;border-radius:6px;flex-direction:column;align-items:flex-start;padding:6px 10px;font-family:inherit;font-size:13px;transition:all .15s;display:flex}.settings-voice-btn:hover:not(:disabled){border-color:var(--border-strong);color:var(--text)}.settings-voice-btn.active{border-color:var(--accent);background:var(--accent-bg);color:var(--accent-text)}.settings-voice-btn:disabled{opacity:.4;cursor:not-allowed}.settings-voice-name{font-size:13px;line-height:1.3}.settings-voice-style{color:var(--text-faint);font-size:10px;line-height:1.2}.settings-voice-btn.active .settings-voice-style{color:var(--accent-desc)}.settings-theme-toggle{gap:6px;display:flex}.settings-theme-btn{border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-tertiary);cursor:pointer;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-family:inherit;font-size:13px;transition:all .15s;display:flex}.settings-theme-btn:hover{border-color:var(--border-strong);color:var(--text)}.settings-theme-btn.active{border-color:var(--accent);background:var(--accent-bg);color:var(--accent-text)}.settings-theme-icon{font-size:15px;line-height:1}.settings-pin-section{flex-direction:column;gap:10px;display:flex}.settings-pin-section-active{background:var(--bg-input);border:1px solid var(--border);border-radius:12px;gap:14px;padding:16px}.settings-pin-status{align-items:center;gap:8px;display:flex}.settings-pin-indicator{border-radius:50%;flex-shrink:0;width:8px;height:8px}.settings-pin-indicator.set{background:var(--green)}.settings-pin-indicator.unset{background:var(--yellow-text)}.settings-pin-label{color:var(--text-tertiary);font-size:13px}.settings-pin-steps{align-items:center;gap:4px;display:flex}.settings-pin-step{flex:1;align-items:center;gap:6px;display:flex}.settings-pin-step-dot{border:1.5px solid var(--pin-step-border);width:22px;height:22px;color:var(--text-ghost);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;font-weight:600;transition:all .2s;display:flex}.settings-pin-step.active .settings-pin-step-dot{border-color:var(--green);color:var(--green);background:var(--green-bg-subtle)}.settings-pin-step.current .settings-pin-step-dot{border-color:var(--accent);color:var(--accent);background:var(--accent-bg);box-shadow:0 0 8px #6e8efb33}.settings-pin-step-label{color:var(--text-ghost);white-space:nowrap;font-size:11px}.settings-pin-step.active .settings-pin-step-label{color:var(--text-muted)}.settings-pin-step.current .settings-pin-step-label{color:var(--text-tertiary);font-weight:500}.settings-pin-instructions{color:var(--text-label);font-size:13px;line-height:1.5}.settings-pin-btn{background:var(--bg-hover);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:8px;align-self:flex-start;padding:8px 20px;font-family:inherit;font-size:13px;transition:all .15s}.settings-pin-btn:hover:not(:disabled){background:var(--bg-hover-strong);border-color:var(--border-hover)}.settings-pin-btn:disabled{opacity:.3;cursor:default}.settings-pin-btn-primary{background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent-text)}.settings-pin-btn-primary:hover:not(:disabled){background:#6e8efb40;border-color:#6e8efb66}.settings-pin-cancel{color:var(--text-faint);cursor:pointer;background:0 0;border:none;padding:8px 12px;font-family:inherit;font-size:13px}.settings-pin-cancel:hover{color:var(--text-tertiary)}.settings-pin-hint{color:var(--text-ghost);margin:0;font-size:12px;line-height:1.5}.settings-pin-input-label{color:var(--text-label);font-size:12px;font-weight:500}.settings-pin-input{background:var(--bg-input);border:1px solid var(--border);color:var(--text);letter-spacing:6px;border-radius:8px;width:120px;padding:10px 14px;font-family:inherit;font-size:18px;transition:border-color .15s}.settings-pin-input-full{box-sizing:border-box;width:100%}.settings-pin-input:focus{border-color:var(--border-input-focus);outline:none;box-shadow:0 0 0 2px #6e8efb1a}.settings-pin-length{align-items:center;gap:10px;display:flex}.settings-pin-length-bar{background:var(--bg-hover);border-radius:2px;flex:1;height:3px;overflow:hidden}.settings-pin-length-fill{background:var(--border-hover);border-radius:2px;height:100%;transition:width .15s,background .15s}.settings-pin-length-fill.valid{background:var(--green)}.settings-pin-length-text{color:var(--text-ghost);white-space:nowrap;text-align:right;min-width:90px;font-size:11px}.settings-pin-length-text.valid{color:var(--green)}.settings-pin-actions{align-items:center;gap:8px;display:flex}.settings-pin-error-banner{background:var(--red-bg);border:1px solid var(--red-border);color:var(--red);border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:12px;line-height:1.4;animation:.2s pin-feedback-in;display:flex}.settings-pin-success-banner{background:var(--green-bg-subtle);color:var(--green);border:1px solid #4ade8033;border-radius:8px;align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:500;animation:.25s pin-feedback-in;display:flex}@keyframes pin-feedback-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.settings-pin-error{color:var(--red);margin:0;font-size:12px}.settings-pin-success{color:var(--green);margin:0;font-size:12px}.user-menu-btn{top:calc(40px + env(safe-area-inset-top,0px));z-index:20;background:var(--bg-hover);border:1px solid var(--border-hover);width:48px;height:48px;color:var(--text-muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;right:28px}.user-menu-btn:hover{color:var(--text);border-color:var(--border-strong);background:var(--bg-hover-strong)}.user-menu-nav{flex-direction:column;gap:4px;display:flex}.user-menu-item{width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;padding:14px 16px;font-family:inherit;font-size:15px;transition:background .15s;display:flex}.user-menu-item:hover{background:var(--bg-hover);color:var(--text)}.user-menu-item-icon{opacity:.7;flex-shrink:0}.user-menu-item:hover .user-menu-item-icon{opacity:1}.user-menu-item-text{flex:1}.user-menu-divider{background:var(--border);height:1px;margin:8px 0}.user-menu-logout{color:var(--red-text)}.user-menu-logout:hover{color:var(--red-hover);background:var(--red-hover-bg)}.user-menu-logout .user-menu-item-icon{opacity:.8}.user-menu-vault-badge{color:#6e8efb;background:#6e8efb1a;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.user-menu-badge{color:var(--yellow-text);background:var(--yellow-bg);text-transform:uppercase;letter-spacing:.3px;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600}.vault-drawer{background:var(--bg-surface-alt);width:420px}.vault-drawer .drawer-body{gap:16px}.vault-protected-banner{background:#6e8efb0f;border:1px solid #6e8efb26;border-radius:12px;gap:12px;padding:14px 16px;display:flex}.vault-protected-icon{color:#6e8efb;background:#6e8efb1f;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.vault-protected-text{flex-direction:column;gap:4px;min-width:0;display:flex}.vault-protected-label{color:#6e8efb;text-transform:uppercase;letter-spacing:.8px;font-size:11px;font-weight:700}.vault-protected-desc{color:var(--text);margin:0;font-size:13px;line-height:1.5}.vault-action-bar{background:var(--bg-surface-alt,#1a1a2e);border:1px solid #6e8efb4d;border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;animation:.25s vault-action-bar-in;display:flex}@keyframes vault-action-bar-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.vault-action-bar--pulse{animation:.6s vault-action-bar-pulse}@keyframes vault-action-bar-pulse{0%{box-shadow:0 0 #6e8efb66}50%{border-color:#6e8efb99;box-shadow:0 0 0 6px #6e8efb26}to{box-shadow:0 0 #6e8efb00}}.vault-action-bar-text{color:var(--text-secondary);font-size:13px;font-weight:500}.vault-action-bar-buttons{flex-shrink:0;gap:8px;display:flex}.vault-action-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border:1px solid #0000;border-radius:8px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.vault-action-btn:active{transform:scale(.93)}.vault-action-btn--cancel{background:var(--bg-hover);border-color:var(--border);color:var(--text-secondary)}.vault-action-btn--cancel:hover{background:var(--bg-hover-strong);border-color:var(--border-hover)}.vault-action-btn--save{color:#fff;background:#6e8efb}.vault-action-btn--save:hover{background:#5a7bf0}.vault-feedback{border-radius:10px;align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:500;animation:.3s vault-feedback-in,.5s 2.5s forwards vault-feedback-out;display:flex}.vault-feedback--save{color:var(--green);background:#4ade801a;border:1px solid #4ade8040}.vault-feedback--cancel{background:var(--bg-hover);border:1px solid var(--border);color:var(--text-secondary)}@keyframes vault-feedback-in{0%{opacity:0;transform:translateY(-6px)scale(.97)}60%{opacity:1;transform:translateY(1px)scale(1.01)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes vault-feedback-out{0%{opacity:1}to{opacity:0;transform:translateY(-4px)}}.vault-card{background:var(--bg-input);border:1px solid var(--border);border-radius:12px;padding:14px 16px}.vault-card label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;font-size:11px;font-weight:600;display:block}.vault-card-hint{color:var(--text);margin:0 0 12px;font-size:12px;line-height:1.4}.vault-empty{color:var(--text);text-align:center;padding:24px 0;font-size:13px;line-height:1.6}.vault-item-list{flex-direction:column;gap:6px;display:flex}.vault-item{background:var(--bg-hover);border:1px solid var(--border);border-radius:10px;align-items:center;gap:10px;min-height:48px;padding:10px 12px;transition:background .15s,border-color .15s;display:flex}.vault-item--editable{cursor:pointer}.vault-item--editable:hover{background:var(--bg-hover-strong);border-color:var(--border-hover)}.vault-item--editing{background:var(--bg-hover-strong);border-color:var(--border-strong)}.vault-item--stress{background:var(--red-bg);border-color:var(--red-border)}.vault-item--stress .vault-item-text,.vault-item--stress .vault-item-btn{color:var(--red)}.vault-item--coping{background:var(--blue-bg);border-color:var(--blue-border)}.vault-item--coping .vault-item-text,.vault-item--coping .vault-item-btn{color:var(--blue-text)}.vault-item-text{color:var(--text);word-break:break-word;flex:1;min-width:0;font-size:14px;line-height:1.4}.vault-item-actions{flex-shrink:0;gap:4px;display:flex}.vault-item-btn{width:36px;height:36px;color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:0 0;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.vault-item-btn:hover{background:var(--bg-hover);border-color:var(--border);color:var(--text)}.vault-item-btn--remove:hover{background:var(--red-bg);border-color:var(--red-border);color:var(--red)}.vault-item-btn--save{color:var(--green)}.vault-item-btn--save:hover{background:#4ade801a;border-color:#4ade8033}.vault-item-btn--cancel:hover{background:var(--red-bg);border-color:var(--red-border);color:var(--red)}.vault-item-edit-input{color:var(--text);background:0 0;border:none;flex:1;min-width:0;padding:4px 0;font-family:inherit;font-size:16px}.vault-item-edit-input:focus{outline:none}.vault-item-empty{color:var(--text);margin:0;padding:8px 0;font-size:13px;font-style:italic}.vault-item-add{gap:8px;margin-top:4px;display:flex}.vault-item-add-input{background:var(--bg-input);border:1px solid var(--border);min-height:48px;color:var(--text-secondary);border-radius:10px;flex:1;padding:10px 14px;font-family:inherit;font-size:16px;transition:border-color .15s}.vault-item-add-input:focus{border-color:var(--border-hover);outline:none}.vault-item-add-input::placeholder{color:var(--text-placeholder)}.vault-item-add-btn{background:var(--bg-input);border:1px solid var(--border);width:48px;height:48px;color:var(--text-ghost);cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.vault-item-add-btn:hover:not(:disabled){color:var(--text-secondary);background:var(--bg-hover-strong);border-color:var(--border-hover)}.vault-item-add-btn:disabled{opacity:.2;cursor:default}.vault-personality-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.vault-trait{background:var(--bg-hover);border-radius:8px;flex-direction:column;gap:2px;padding:8px 10px;display:flex}.vault-trait-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px}.vault-trait-value{color:var(--text);font-size:13px;line-height:1.4}.vault-wellbeing{flex-wrap:wrap;align-items:baseline;gap:10px;display:flex}.vault-wellbeing-score{font-size:22px;font-weight:700}.vault-wellbeing-trend{color:var(--text);font-size:12px;font-style:italic}.vault-wellbeing-note{color:var(--text);margin:6px 0 0;font-size:13px;line-height:1.4}.vault-reset{justify-content:flex-end;padding-top:8px;display:flex}.vault-pin{flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:400px;padding:40px 20px;display:flex}.vault-pin-lock{color:var(--text-dimmer)}.vault-pin-title{color:var(--text-muted);margin:0;font-size:18px;font-weight:600}.vault-pin-subtitle{color:var(--text-ghost);text-align:center;margin:-8px 0 0;font-size:13px;line-height:1.4}.vault-pin-display{flex-direction:column;align-items:center;gap:6px;min-height:32px;display:flex}.vault-pin-dots{align-items:center;gap:12px;min-height:16px;display:flex}.vault-pin-dot{border:1.5px solid var(--pin-dot);background:0 0;border-radius:50%;width:14px;height:14px;transition:background .1s,border-color .1s}.vault-pin-dot.filled{background:var(--pin-dot);animation:.12s pin-dot-in}.vault-pin-dot.error{background:var(--red);border-color:var(--red);animation:.4s pin-shake}@keyframes pin-dot-in{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.vault-pin-step-row{align-items:center;gap:0;width:80px;display:flex}.vault-pin-step-pip{border:2px solid var(--pin-step-border);background:0 0;border-radius:50%;flex-shrink:0;width:10px;height:10px;transition:all .2s}.vault-pin-step-pip.current{border-color:var(--accent);background:var(--accent);box-shadow:0 0 8px #6e8efb4d}.vault-pin-step-pip.done{border-color:var(--green);background:var(--green)}.vault-pin-step-line{background:var(--border);flex:1;height:2px}@keyframes pin-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.vault-pin-error{color:var(--red);margin:-8px 0 0;font-size:13px;animation:.2s pin-feedback-slide}.vault-pin-success{color:var(--green);margin:-8px 0 0;font-size:13px;font-weight:500;animation:.2s pin-feedback-slide}@keyframes pin-feedback-slide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.vault-pin-lockout{color:var(--yellow-text);margin:-8px 0 0;font-size:13px;font-weight:500}.vault-pin-hint{color:var(--text-ghost);margin:8px 0 0;font-size:11px}.vault-pin-pad{-webkit-user-select:none;user-select:none;grid-template-columns:repeat(3,1fr);gap:10px;width:min(100%,320px);display:grid}.vault-pin-key{background:var(--bg-input);border:1px solid var(--border);width:100%;height:64px;color:var(--text-secondary);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;border-radius:14px;justify-content:center;align-items:center;font-family:inherit;font-size:24px;font-weight:500;transition:border-color 80ms;display:flex}.vault-pin-key:hover{background:var(--bg-hover-strong);border-color:var(--border-hover)}.vault-pin-key:active,.vault-pin-key.pressing{background:var(--bg-hover-strong);border-color:var(--border-strong);transform:scale(.95)}.vault-pin-key.delete{color:var(--text-faint)}.vault-pin-key.delete:hover{color:var(--text-tertiary)}.vault-pin-key.delete:active,.vault-pin-key.delete.pressing{color:var(--text-secondary)}.vault-pin-key:disabled{opacity:.3;cursor:default}.history-empty{color:var(--text-faint);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:60px 20px;font-size:14px;display:flex}.history-empty-sub{color:var(--text-dimmer);font-size:12px}.history-item{background:var(--bg-input);border:1px solid var(--border);border-radius:12px;padding:14px 16px;transition:border-color .2s,opacity .2s}.history-item:hover{border-color:var(--border-hover)}.history-item.loading{opacity:.5;pointer-events:none}.history-item-info{margin-bottom:12px}.history-item-title{color:var(--text);margin:0 0 6px;font-size:14px;font-weight:500;line-height:1.3}.history-item-meta{color:var(--text-faint);align-items:center;gap:6px;font-size:12px;display:flex}.history-dot{background:var(--text-dimmer);border-radius:50%;width:3px;height:3px}.history-item-actions{gap:8px;display:flex}.history-btn{border:1px solid var(--border);background:var(--bg-input);color:var(--text-tertiary);cursor:pointer;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-size:12px;transition:all .2s;display:flex}.history-btn:hover:not(:disabled){background:var(--bg-hover-strong);color:var(--text);border-color:var(--border-strong)}.history-btn:disabled{opacity:.4;cursor:not-allowed}.history-btn-text:hover:not(:disabled){border-color:var(--accent-border);color:var(--accent)}.history-btn-voice:hover:not(:disabled){color:#fb6e8e;border-color:#fb6e8e66}.history-loading-overlay{background:var(--bg-loading-overlay);z-index:10;border-radius:0;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:absolute;inset:0}.history-loading-overlay p{color:var(--text-tertiary);font-size:14px}.history-spinner{border:3px solid var(--spinner-track);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite history-spin}@keyframes history-spin{to{transform:rotate(360deg)}}.policy-drawer{padding:0 4px}.policy-draft-banner{letter-spacing:1.5px;text-transform:uppercase;color:var(--yellow-text);background:var(--yellow-bg);border-radius:6px;margin-bottom:20px;padding:4px 14px;font-size:11px;font-weight:700;display:inline-block}.policy-section{margin-bottom:24px}.policy-section h3{color:var(--text);margin:0 0 8px;font-size:15px;font-weight:600}.policy-section p{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.6}.policy-section ul{margin:0;padding-left:20px;list-style:outside}.policy-section li{color:var(--text-secondary);margin-bottom:6px;font-size:14px;line-height:1.6}.policy-section li:last-child{margin-bottom:0}.onboarding{z-index:100;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.onboarding-welcome{flex-direction:column;align-items:center;gap:24px;display:flex}.onboarding-welcome-orb{cursor:pointer;position:relative}.onboarding-welcome-tap{color:var(--text-muted);white-space:nowrap;font-size:13px;animation:2s ease-in-out infinite onboarding-pulse;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)}@keyframes onboarding-pulse{0%,to{opacity:.5}50%{opacity:1}}.onboarding-wizard{flex-direction:column;align-items:center;gap:28px;width:100%;max-width:380px;padding:0 24px;animation:.4s ease-out onboarding-fade-in;display:flex}@keyframes onboarding-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.onboarding-progress{align-items:center;gap:8px;display:flex}.onboarding-progress-dot{background:var(--border);border-radius:50%;width:8px;height:8px;transition:background .3s,transform .3s}.onboarding-progress-dot.active{background:var(--accent);transform:scale(1.25)}.onboarding-progress-dot.done{background:var(--green)}.onboarding-step{text-align:center;flex-direction:column;align-items:center;gap:20px;width:100%;display:flex}.onboarding-step h2{color:var(--text);letter-spacing:-.02em;font-size:22px;font-weight:600}.onboarding-step p{color:var(--text-muted);max-width:320px;font-size:14px;line-height:1.5}.onboarding-name-input{border:1px solid var(--border);background:var(--bg-input);width:100%;max-width:260px;color:var(--text);text-align:center;letter-spacing:.02em;border-radius:12px;outline:none;padding:14px 16px;font-size:20px;font-weight:500;transition:border-color .2s}.onboarding-name-input:focus{border-color:var(--accent)}.onboarding-name-input::placeholder{color:var(--text-placeholder);font-weight:400}.onboarding-char-count{color:var(--text-faint);font-size:12px}.onboarding-char-count.warning{color:var(--yellow-text)}.onboarding-pin-section{flex-direction:column;align-items:center;gap:16px;width:100%;display:flex}.onboarding-pin-steps{align-items:center;gap:20px;margin-bottom:4px;display:flex}.onboarding-pin-step{opacity:.4;flex-direction:column;align-items:center;gap:4px;transition:opacity .2s;display:flex}.onboarding-pin-step.active{opacity:1}.onboarding-pin-step-dot{border:1.5px solid var(--pin-step-border);width:28px;height:28px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:12px;transition:all .2s;display:flex}.onboarding-pin-step.active .onboarding-pin-step-dot{border-color:var(--accent);color:var(--accent)}.onboarding-pin-step.done .onboarding-pin-step-dot{border-color:var(--green);color:var(--green)}.onboarding-pin-step-label{color:var(--text-faint);font-size:11px}.onboarding-pin-input{border:1px solid var(--border);background:var(--bg-input);width:200px;color:var(--text);text-align:center;letter-spacing:.3em;border-radius:12px;outline:none;padding:12px 16px;font-size:24px;font-weight:500;transition:border-color .2s}.onboarding-pin-input:focus{border-color:var(--accent)}.onboarding-pin-hint{color:var(--text-faint);font-size:12px}.onboarding-pin-length{align-items:center;gap:8px;display:flex}.onboarding-pin-length-bar{background:var(--border);border-radius:2px;width:100px;height:3px;overflow:hidden}.onboarding-pin-length-fill{background:var(--text-faint);border-radius:2px;height:100%;transition:width .15s,background .15s}.onboarding-pin-length-fill.valid{background:var(--green)}.onboarding-pin-length-text{color:var(--text-faint);font-size:11px}.onboarding-pin-length-text.valid{color:var(--green)}.onboarding-gestures{flex-direction:column;gap:16px;width:100%;display:flex}.onboarding-gesture-item{background:var(--bg-hover);border-radius:12px;align-items:center;gap:14px;padding:12px 16px;display:flex}.onboarding-gesture-icon{background:var(--accent-bg);width:40px;height:40px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.onboarding-gesture-text{flex-direction:column;gap:2px;display:flex}.onboarding-gesture-title{color:var(--text);font-size:14px;font-weight:500}.onboarding-gesture-desc{color:var(--text-muted);font-size:12px}.onboarding-actions{flex-direction:column;align-items:center;gap:10px;width:100%;display:flex}.onboarding-btn{cursor:pointer;background:var(--accent);color:#fff;border:none;border-radius:12px;width:100%;max-width:260px;padding:14px 24px;font-size:15px;font-weight:500;transition:all .2s}.onboarding-btn:hover:not(:disabled){filter:brightness(1.1)}.onboarding-btn:disabled{opacity:.4;cursor:default}.onboarding-btn-secondary{border:1px solid var(--border);color:var(--text-muted);background:0 0}.onboarding-btn-secondary:hover:not(:disabled){background:var(--bg-hover);filter:none}.onboarding-error{background:var(--red-bg);border:1px solid var(--red-border);color:var(--red-text);border-radius:8px;align-items:center;gap:8px;padding:10px 14px;font-size:13px;display:flex}.auth-page{background:var(--bg);justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex}.auth-card{flex-direction:column;gap:32px;width:100%;max-width:380px;display:flex}.auth-logo{flex-direction:column;align-items:center;gap:16px;display:flex}.auth-orb{background:radial-gradient(circle at 40% 40%,#6e8efb,#4a3f9f);border-radius:50%;width:56px;height:56px;box-shadow:0 0 40px #6e8efb4d}.auth-title{color:var(--text);letter-spacing:-.02em;font-size:22px;font-weight:600}.auth-form{flex-direction:column;gap:18px;display:flex}.auth-heading{color:var(--text-tertiary);text-align:center;font-size:16px;font-weight:500}.auth-label{color:var(--text-muted);flex-direction:column;gap:6px;font-size:13px;display:flex}.auth-input{border:1px solid var(--border);background:var(--bg-input);color:var(--text);border-radius:10px;outline:none;padding:12px 14px;font-size:16px;transition:border-color .2s,background .2s}.auth-input:focus{border-color:var(--border-input-focus);background:var(--bg-hover)}.auth-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6e8efb,#4a3f9f);border:none;border-radius:10px;margin-top:4px;padding:12px;font-size:15px;font-weight:500;transition:opacity .2s}.auth-submit:hover:not(:disabled){opacity:.9}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-error{background:var(--red-bg);border:1px solid var(--red-border);color:var(--red-text);border-radius:8px;padding:10px 14px;font-size:13px}.auth-info{background:var(--accent-bg);border:1px solid var(--accent-border);color:var(--accent-text);border-radius:8px;padding:10px 14px;font-size:13px}.auth-switch{text-align:center;color:var(--text-faint);font-size:13px}.auth-switch-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px}.auth-switch-btn:hover{text-decoration:underline}.app{background:var(--bg);width:100%;height:100%;padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px);flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.app.intro-active .app-chrome{opacity:0;pointer-events:none}.app-chrome{transition:opacity .5s ease-out}.welcome-text{text-align:center;color:var(--text-muted);letter-spacing:-.01em;z-index:5;font-size:17px;font-weight:500;animation:.5s ease-out 1s both welcome-text-in;position:absolute;bottom:30%;left:0;right:0}@keyframes welcome-text-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.mode-toggle{top:calc(40px + env(safe-area-inset-top,0px));background:var(--bg-hover);z-index:10;border-radius:14px;gap:4px;padding:5px;display:flex;position:absolute;left:28px}.mode-toggle.disabled{pointer-events:none}.mode-btn{color:var(--text-faint);cursor:pointer;background:0 0;border:none;border-radius:10px;padding:8px 18px;font-size:15px;transition:all .2s}.mode-btn:hover:not(:disabled){color:var(--text-muted)}.mode-btn.active{background:var(--bg-hover-strong);color:var(--text)}.mode-btn:disabled{cursor:default}
