*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #ededed;--header-bg: #2e2e2e;--header-text: #fff;--bubble-user: #95ec69;--bubble-assistant: #fff;--text-primary: #111;--text-secondary: #888;--input-bg: #fff;--border: #d9d9d9;--accent: #07c160;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}body{font-family:SF Pro Display,PingFang SC,Noto Sans SC,-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.auth-screen{display:flex;align-items:center;justify-content:center;width:100%;height:100dvh;align-self:stretch;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);padding:var(--space-md);padding-top:max(var(--space-md),var(--safe-top));padding-bottom:max(var(--space-md),var(--safe-bottom))}.auth-card{background:#fff;border-radius:16px;padding:36px 24px;width:100%;max-width:calc(100% - 32px);text-align:center;box-shadow:0 20px 60px #0000004d;transition:transform .3s ease,box-shadow .3s ease}.auth-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;margin:0 auto 20px}.auth-title{font-size:22px;font-weight:600;margin-bottom:4px}.auth-subtitle{color:var(--text-secondary);font-size:13px;margin-bottom:28px}.auth-input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:8px;font-size:14px;outline:none;transition:border-color .2s ease,box-shadow .2s ease;font-family:monospace}.auth-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #07c1601a}.auth-button{width:100%;padding:12px;margin-top:16px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:opacity .2s ease,transform .1s ease}.auth-button:active{transform:scale(.98)}.auth-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-error{color:#e53935;font-size:13px;margin-top:12px}#app{width:100%;height:100dvh;display:flex;flex-direction:column;background:var(--bg);position:relative}.chat-container{display:flex;flex-direction:column;height:100dvh}.chat-header{background:var(--header-bg);color:var(--header-text);padding:12px 16px;padding-top:max(12px,var(--safe-top));padding-left:max(16px,var(--safe-left));padding-right:max(16px,var(--safe-right));display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.chat-header-name{font-size:16px;font-weight:600}.chat-header-sub{display:block;font-size:11px;color:#aaa;margin-top:2px}.chat-header-right{display:flex;gap:var(--space-sm)}.header-btn{background:none;border:none;color:#aaa;cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;transition:color .2s ease,background .2s ease}.name-editable{cursor:pointer;border-bottom:1px dashed #666;transition:border-color .2s ease}.name-editable:hover{border-bottom-color:var(--accent)}.name-edit-input{background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:3px;color:#aaa;font-size:inherit;font-family:inherit;padding:0 4px;outline:none;width:80px}.name-edit-input:focus{border-color:var(--accent);background:#fff3}.messages-area{flex:1;overflow-y:auto;padding:var(--space-md) 12px;padding-left:max(12px,var(--safe-left));padding-right:max(12px,var(--safe-right));display:flex;flex-direction:column;gap:var(--space-xs);-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#ccc transparent}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary);gap:12px}.empty-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;opacity:.5}.empty-state p{font-size:14px}.loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.message-row{display:flex;align-items:flex-start;gap:var(--space-sm);max-width:90%;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.message-row.user{align-self:flex-end}.message-row.assistant{align-self:flex-start}.avatar{width:36px;height:36px;border-radius:4px;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-yichen{object-fit:cover}.avatar-user{background:#4a90d9;color:#fff;font-size:11px}.avatar-spacer{visibility:hidden}.message-group{display:flex;flex-direction:column;max-width:90%;animation:fadeIn .15s ease}.message-group.user{align-self:flex-end;align-items:flex-end}.message-group.assistant{align-self:flex-start;align-items:flex-start}.message-group>.message-row{max-width:100%;animation:none;align-self:auto}.message-name{font-size:11px;color:var(--text-secondary, #999);margin-bottom:2px;padding:0 2px}.message-name-left{padding-left:0}.message-name-right{padding-right:0}.avatar-user-img{width:36px;height:36px;border-radius:4px;object-fit:cover}.bubble{padding:8px 12px;border-radius:4px;font-size:15px;line-height:1.5;word-break:break-word;position:relative}.bubble-user{background:var(--bubble-user);color:#000}.bubble-assistant{background:var(--bubble-assistant);color:#000}.bubble.streaming:after{content:"▊";animation:blink .8s infinite;opacity:.5;margin-left:1px}@keyframes blink{0%,to{opacity:0}50%{opacity:.5}}.chat-status{display:flex;align-items:center;gap:6px;padding:4px 16px;font-size:12px;color:#888;background:#f7f7f7;border-top:1px solid var(--border)}.chat-status-dot{width:6px;height:6px;border-radius:50%;background:#4caf50;animation:pulse 1.2s infinite}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.input-bar{display:flex;align-items:flex-end;gap:var(--space-sm);padding:8px 12px;padding-bottom:max(8px,var(--safe-bottom));padding-left:max(12px,var(--safe-left));padding-right:max(12px,var(--safe-right));background:#f7f7f7;border-top:1px solid var(--border);flex-shrink:0}.input-textarea{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:4px;font-size:15px;resize:none;outline:none;background:#fff;font-family:inherit;max-height:120px;line-height:1.4;overflow-y:auto;transition:border-color .2s ease,box-shadow .2s ease}.input-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px #07c16014}.send-button{background:var(--accent);color:#fff;border:none;border-radius:4px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;flex-shrink:0;transition:opacity .2s ease,transform .1s ease}.send-button:active:not(:disabled){transform:scale(.96)}.send-button:disabled{background:#ccc;cursor:not-allowed}.messages-area::-webkit-scrollbar{width:4px}.messages-area::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}@media(min-width:480px){.auth-card{max-width:380px;padding:44px 32px}.auth-avatar{width:72px;height:72px}.auth-title{font-size:24px}.auth-subtitle{font-size:14px;margin-bottom:32px}.message-row{max-width:85%}}@media(min-width:768px){body{background:linear-gradient(135deg,#e8e8e8,#d5d5d5,#c8c8c8)}#app{background:transparent;height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.auth-card{max-width:400px;padding:56px 40px}.auth-avatar{width:80px;height:80px}.chat-container{width:90%;max-width:800px;height:calc(100dvh - 40px);border-radius:12px;box-shadow:0 4px 24px #00000014,0 1px 4px #0000000a;overflow:hidden}.chat-header{border-radius:12px 12px 0 0;padding:14px 20px}.messages-area{gap:6px;background:var(--bg);padding:20px 24px}.message-row{max-width:70%}.bubble{padding:10px 14px;border-radius:6px}.avatar{width:40px;height:40px}.avatar-yichen{object-fit:cover}.input-bar{border-radius:0 0 12px 12px;padding:10px 16px}.input-textarea{padding:10px 14px;border-radius:6px}.send-button{padding:10px 20px;border-radius:6px}.empty-avatar{width:80px;height:80px}.empty-state p{font-size:15px}.messages-area::-webkit-scrollbar{width:6px}}@media(min-width:1024px){.chat-container{width:80%;max-width:900px;box-shadow:0 8px 40px #0000001f,0 2px 8px #0000000f}.auth-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;box-shadow:0 24px 80px #00000040,0 4px 12px #0000001a}.message-row{max-width:65%}}@media(hover:hover){.auth-button:hover:not(:disabled){opacity:.9}.header-btn:hover{color:#fff;background:#ffffff1a}.send-button:hover:not(:disabled){opacity:.9}.auth-card:hover{transform:translateY(-2px);box-shadow:0 24px 72px #00000059}}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md);animation:onboarding-fade-in .25s ease}@keyframes onboarding-fade-in{0%{opacity:0}to{opacity:1}}.onboarding-card{background:#fff;border-radius:16px;padding:28px 24px 24px;width:100%;max-width:340px;text-align:center;box-shadow:0 20px 60px #0000004d;animation:onboarding-slide-up .3s ease}@keyframes onboarding-slide-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.onboarding-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.onboarding-badge{font-size:11px;font-weight:600;color:var(--accent);background:#07c1601a;padding:3px 10px;border-radius:20px}.onboarding-skip{font-size:13px;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:4px 8px}.onboarding-skip:hover{color:var(--text-primary)}.onboarding-icon-wrap{width:52px;height:52px;border-radius:14px;background:#07c1601a;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--accent)}.onboarding-title{font-size:18px;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.onboarding-desc{font-size:14px;color:var(--text-secondary);line-height:1.5;margin-bottom:20px}.onboarding-dots{display:flex;justify-content:center;gap:6px;margin-bottom:20px}.onboarding-dot{width:7px;height:7px;border-radius:50%;background:var(--border);transition:background .2s,transform .2s}.onboarding-dot.active{background:var(--accent);transform:scale(1.3)}.onboarding-actions{display:flex;gap:10px;justify-content:center}.onboarding-btn{padding:10px 24px;border-radius:10px;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:opacity .15s}.onboarding-btn:hover{opacity:.85}.onboarding-btn.primary{background:var(--accent);color:#fff;flex:1}.onboarding-btn.secondary{background:#f0f0f0;color:var(--text-primary)}.admin-container{width:100%;max-width:1400px;margin:0 auto;padding:var(--space-md);padding-top:max(var(--space-md),var(--safe-top));padding-bottom:max(var(--space-md),var(--safe-bottom));padding-left:max(var(--space-md),var(--safe-left));padding-right:max(var(--space-md),var(--safe-right));min-height:100dvh}.admin-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}.admin-title{font-size:20px;font-weight:700}.admin-subtitle{font-size:13px;color:var(--text-secondary)}.admin-header-right{display:flex;gap:var(--space-sm)}.admin-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:28px}.stat-card{background:#fff;border-radius:10px;padding:14px;border:1px solid var(--border);transition:box-shadow .2s ease}.stat-value{font-size:22px;font-weight:700;color:var(--text-primary)}.stat-label{font-size:12px;color:var(--text-secondary);margin-top:4px}.stat-sub{font-size:11px;color:var(--text-secondary);margin-top:2px}.admin-section{margin-bottom:24px}.section-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:12px}.section-header h2{font-size:16px;font-weight:600}.search-input{padding:6px 12px;border:1px solid var(--border);border-radius:6px;font-size:13px;outline:none;width:100%;max-width:200px;transition:border-color .2s ease}.search-input:focus{border-color:var(--accent)}.keys-list{display:flex;flex-direction:column;gap:12px}.key-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:14px;transition:box-shadow .2s ease}.key-card.key-disabled{opacity:.6;background:#fafafa}.key-header{margin-bottom:10px}.key-name{font-size:15px;font-weight:600;display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.key-id{font-size:11px;color:var(--text-secondary);font-family:monospace}.badge{font-size:10px;padding:2px 6px;border-radius:4px;font-weight:500}.badge-disabled{background:#fce4ec;color:#c62828}.badge-cleared{background:#fff3e0;color:#e65100}.key-stats-row{display:flex;gap:12px;margin-bottom:8px;flex-wrap:wrap}.key-stat{display:flex;flex-direction:column;min-width:0}.key-stat-label{font-size:11px;color:var(--text-secondary)}.key-stat-value{font-size:14px;font-weight:600}.token-bar{height:4px;background:#eee;border-radius:2px;margin-bottom:8px;overflow:hidden}.token-bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.key-meta{display:flex;gap:12px;font-size:11px;color:var(--text-secondary);margin-bottom:10px;flex-wrap:wrap}.key-actions{display:flex;gap:var(--space-sm);align-items:center;flex-wrap:wrap}.token-add-group{display:flex;gap:4px;align-items:center}.token-input{width:90px;padding:4px 8px;border:1px solid var(--border);border-radius:4px;font-size:12px;outline:none;transition:border-color .2s ease}.token-input:focus{border-color:var(--accent)}.btn{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:opacity .2s ease,transform .1s ease}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:5px 12px;font-size:12px}.btn-primary{background:var(--accent);color:#fff}.btn-danger{background:#e53935;color:#fff}.btn-success{background:#43a047;color:#fff}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-primary)}.key-messages{margin-top:12px;border-top:1px solid #eee;padding-top:12px;max-height:300px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#ccc transparent}.msg-row{display:flex;gap:var(--space-sm);padding:4px 0;font-size:13px;line-height:1.4;flex-wrap:wrap}.msg-row.msg-user{background:#f9f9f9;padding:4px 6px;border-radius:4px}.msg-time{color:var(--text-secondary);font-size:11px;flex-shrink:0;width:90px}.msg-role{font-weight:600;flex-shrink:0;width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-content{word-break:break-word;min-width:0;flex:1}.msg-empty{text-align:center;color:var(--text-secondary);padding:20px;font-size:13px}.msg-load-more{display:block;margin:8px auto 0}.admin-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:2px solid var(--border)}.admin-tab{padding:8px 20px;font-size:14px;font-weight:500;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;color:var(--text-secondary);transition:color .2s ease,border-color .2s ease}.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-chat{display:flex;flex-direction:column;gap:12px}.admin-chat-toolbar{display:flex;gap:var(--space-sm);align-items:center;flex-wrap:wrap}.admin-chat-select{flex:1;min-width:200px;padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-size:13px;outline:none;background:#fff;transition:border-color .2s ease}.admin-chat-select:focus{border-color:var(--accent)}.admin-chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 20px;color:var(--text-secondary);font-size:14px}.admin-chat-window{display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--border);border-radius:10px;overflow:hidden;height:calc(100dvh - 220px);min-height:300px}.admin-chat-messages{flex:1;overflow-y:auto;padding:var(--space-md) 12px;display:flex;flex-direction:column;gap:6px;scrollbar-width:thin;scrollbar-color:#ccc transparent}.admin-chat-messages::-webkit-scrollbar{width:4px}.admin-chat-messages::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}.admin-msg-wrapper{display:flex;flex-direction:column;gap:var(--space-xs);max-width:90%}.admin-msg-right{align-self:flex-end}.admin-msg-left{align-self:flex-start}.admin-msg-cleared{opacity:.45}.admin-msg-wrapper .message-row{align-self:auto;max-width:100%}.admin-msg-wrapper .message-group{max-width:100%}.admin-msg-meta{display:flex;align-items:center;gap:6px;margin-bottom:2px}.admin-msg-sender{font-size:11px;color:var(--text-secondary)}.badge-admin{background:#e3f2fd;color:#1565c0;font-size:10px;padding:1px 6px;border-radius:3px;font-weight:500}.badge-user-source{background:#f3e5f5;color:#7b1fa2;font-size:10px;padding:1px 6px;border-radius:3px;font-weight:500}.avatar-admin{background:#1565c0;color:#fff;font-size:11px}.debug-info{display:flex;gap:12px;padding:4px 12px;margin:2px 0 4px 44px;font-size:11px;color:var(--text-secondary);background:#f5f5f5;border-radius:4px;flex-wrap:wrap}.debug-info.debug-error{background:#fce4ec;color:#c62828}.debug-info.debug-info-right{margin-left:auto;margin-right:44px}.admin-mode-toggle{display:flex;gap:4px}.btn-active{background:var(--accent);color:#fff;border-color:var(--accent)}.memory-search-result{padding:12px}.vector-stats-panel{background:#f0f4ff;border:1px solid #d0d8f0;border-radius:8px;padding:12px 16px;margin-bottom:12px;display:flex;flex-direction:column;gap:8px}.vector-stats-title{font-size:13px;font-weight:600;color:#333}.vector-stats-grid{display:flex;gap:24px}.vector-stats-item{display:flex;flex-direction:column;align-items:center}.vector-stats-value{font-size:20px;font-weight:700;color:#2563eb}.vector-stats-label{font-size:11px;color:#666;margin-top:2px}.memory-search-meta{display:flex;gap:8px;align-items:center;font-size:12px;color:#666;margin-bottom:8px}.memory-search-result .memory-debug-chunks{max-height:none}.memory-debug{width:100%;margin-top:4px;border-top:1px solid #e0e0e0;padding-top:4px}.memory-debug-header{display:flex;gap:8px;align-items:center;cursor:pointer;font-weight:500}.memory-debug-header:hover{color:#333}.memory-debug-toggle{font-size:10px;margin-left:auto}.memory-debug-error{color:#c62828}.memory-debug-chunks{margin-top:4px;max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.memory-debug-chunk{background:#fff;border:1px solid #e8e8e8;border-radius:4px;padding:4px 8px}.memory-debug-chunk-meta{display:flex;gap:8px;font-size:10px;color:#888;margin-bottom:2px}.memory-debug-score{font-weight:600;color:#1976d2}.memory-debug-chunk-text{font-size:11px;line-height:1.4;white-space:pre-wrap;word-break:break-all;margin:0;color:#444}@media(max-width:479px){.admin-container{padding:12px;padding-top:max(12px,var(--safe-top));padding-bottom:max(12px,var(--safe-bottom))}.admin-title{font-size:18px}.admin-stats{grid-template-columns:1fr 1fr;gap:8px}.stat-card{padding:12px}.stat-value{font-size:18px}.key-card{padding:12px}.key-actions{flex-direction:column;align-items:stretch}.key-actions .btn-sm{text-align:center}.token-add-group{width:100%}.token-input{flex:1;width:auto}.search-input{max-width:none}.section-header{flex-direction:column;align-items:flex-start}.msg-time,.msg-role{width:auto}.msg-row{font-size:12px}.key-messages{max-height:250px}}@media(min-width:480px)and (max-width:767px){.admin-stats{grid-template-columns:repeat(2,1fr)}.key-stats-row{gap:16px}}@media(min-width:768px){body:has(.admin-container){background:var(--bg)}#app:has(.admin-container){align-items:stretch;justify-content:flex-start;padding:0;height:auto;min-height:100dvh}.admin-container{padding:var(--space-lg)}.admin-stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.admin-title{font-size:22px}.key-card{padding:16px}.key-messages{max-height:400px}.admin-chat-messages{padding:20px 24px}}@media(min-width:1024px){.admin-container{padding:32px 48px}.keys-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.admin-stats{grid-template-columns:repeat(4,1fr)}}@media(hover:hover){.btn:hover:not(:disabled){opacity:.85}.stat-card:hover,.key-card:hover{box-shadow:0 2px 12px #0000000f}}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}.settings-panel{background:var(--bg-primary, #fff);border-radius:12px;width:90%;max-width:400px;max-height:80vh;overflow-y:auto;padding:24px;box-shadow:0 8px 32px #00000026}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.settings-header h2{margin:0;font-size:18px}.settings-close{background:none;border:none;cursor:pointer;padding:4px;color:var(--text-secondary, #999);border-radius:4px}.settings-close:hover{background:#f0f0f0}.settings-section{margin-bottom:20px}.settings-label{display:block;font-size:13px;font-weight:600;margin-bottom:4px;color:var(--text-primary, #333)}.settings-hint{font-size:12px;color:var(--text-secondary, #999);margin:0 0 8px}.settings-input-row{display:flex;gap:8px;align-items:center}.settings-input{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;outline:none}.settings-input:focus{border-color:var(--accent, #4a90d9)}.settings-error{color:#e53935;font-size:13px;margin:8px 0 0}.settings-delete-avatar{margin-left:8px}.avatar-upload-area{display:flex;align-items:center;gap:12px;margin-top:8px}.avatar-upload-preview{width:64px;height:64px;border-radius:8px;overflow:hidden;position:relative;cursor:pointer;flex-shrink:0}.avatar-upload-img{width:100%;height:100%;object-fit:cover}.avatar-upload-placeholder{width:100%;height:100%;background:#4a90d9;color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600}.avatar-upload-hover{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;opacity:0;transition:opacity .15s}.avatar-upload-preview:hover .avatar-upload-hover{opacity:1}.avatar-file-input{display:none}.key-name-row{display:flex;align-items:center;gap:10px}.key-avatar-thumb{width:36px;height:36px;border-radius:4px;object-fit:cover;flex-shrink:0}.key-avatar-placeholder{background:#4a90d9;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.key-display-name{color:var(--text-secondary, #999);font-size:12px;margin-left:4px}.key-nickname{font-size:11px;color:var(--text-secondary, #999);margin-top:2px}.key-card.key-disabled-auto{border-left:3px solid #e53935;background:#fff5f5}.badge-danger{background:#e53935;color:#fff}.key-disabled-reason{font-size:11px;color:var(--text-secondary, #999);margin-top:2px}.key-disabled-reason.key-disabled-auto{color:#e53935;font-weight:600}
