.contacts-page { display: flex; height: calc(100% + 48px); margin: -24px; background: var(--bg-primary); overflow: hidden; // 左侧联系人面板 .contacts-panel { width: 380px; min-width: 380px; display: flex; flex-direction: column; border-right: 1px solid var(--border-color); background: var(--card-bg); } .panel-header { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid var(--border-color); h2 { font-size: 18px; font-weight: 600; color: var(--text-primary); margin: 0; } .icon-btn { width: 32px; height: 32px; border: none; background: var(--bg-tertiary); border-radius: 8px; cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--text-secondary); transition: all 0.2s; &:hover { background: var(--bg-hover); color: var(--text-primary); } &:disabled { opacity: 0.5; cursor: not-allowed; } .spin { animation: contactsSpin 1s linear infinite; } } } .search-bar { display: flex; align-items: center; gap: 10px; margin: 16px 20px; padding: 10px 14px; background: var(--bg-secondary); border-radius: 10px; border: 1px solid var(--border-color); transition: border-color 0.2s; &:focus-within { border-color: var(--primary); } svg { color: var(--text-tertiary); flex-shrink: 0; } input { flex: 1; border: none; background: none; outline: none; font-size: 14px; color: var(--text-primary); &::placeholder { color: var(--text-tertiary); } } .clear-btn { background: none; border: none; padding: 4px; cursor: pointer; color: var(--text-tertiary); display: flex; align-items: center; justify-content: center; border-radius: 4px; &:hover { background: var(--bg-hover); color: var(--text-primary); } } } .type-filters { display: flex; gap: 12px; padding: 0 20px 12px; flex-wrap: nowrap; overflow-x: auto; /* Allow horizontal scroll if needed on very small screens */ /* Hide scrollbar */ &::-webkit-scrollbar { display: none; } .filter-checkbox { display: flex; /* Changed to flex with padding */ align-items: center; gap: 8px; cursor: pointer; user-select: none; font-size: 14px; color: var(--text-primary); padding: 6px 12px; background: var(--bg-secondary); border-radius: 8px; transition: all 0.2s; &:hover { background: var(--bg-hover); } input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--primary); cursor: pointer; opacity: 1; /* Make visible */ position: static; /* Make static */ pointer-events: auto; /* Enable pointer events */ } svg { color: var(--text-secondary); flex-shrink: 0; margin-left: 2px; } } } .contacts-count { padding: 0 20px 12px; font-size: 13px; color: var(--text-secondary); } .loading-state, .empty-state { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; color: var(--text-tertiary); font-size: 14px; .spin { animation: contactsSpin 1s linear infinite; } } .contacts-list { flex: 1; overflow-y: auto; padding: 0 12px 12px; &::-webkit-scrollbar { width: 6px; } &::-webkit-scrollbar-thumb { background: var(--text-tertiary); border-radius: 3px; opacity: 0.3; } } .contact-item { display: flex; align-items: center; gap: 12px; padding: 12px; border-radius: 10px; transition: all 0.2s; margin-bottom: 4px; &:hover { background: var(--bg-hover); } .contact-avatar { width: 44px; height: 44px; border-radius: 10px; background: linear-gradient(135deg, var(--primary), var(--primary-hover)); display: flex; align-items: center; justify-content: center; overflow: hidden; flex-shrink: 0; img { width: 100%; height: 100%; object-fit: cover; } span { color: #fff; font-size: 16px; font-weight: 600; } } .contact-info { flex: 1; min-width: 0; } .contact-name { font-size: 14px; font-weight: 500; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .contact-remark { font-size: 12px; color: var(--text-tertiary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 2px; } .contact-type { display: flex; align-items: center; gap: 4px; padding: 4px 10px; border-radius: 6px; font-size: 12px; font-weight: 500; flex-shrink: 0; &.friend { background: rgba(var(--primary-rgb), 0.1); color: var(--primary); } &.group { background: rgba(52, 211, 153, 0.1); color: rgb(52, 211, 153); } &.official { background: rgba(251, 191, 36, 0.1); color: rgb(251, 191, 36); } svg { flex-shrink: 0; } } } // 右侧设置面板 .settings-panel { flex: 1; display: flex; flex-direction: column; overflow: hidden; } .settings-content { flex: 1; overflow-y: auto; padding: 20px 24px; &::-webkit-scrollbar { width: 6px; } &::-webkit-scrollbar-thumb { background: var(--text-tertiary); border-radius: 3px; } } .setting-section { margin-bottom: 28px; h3 { font-size: 13px; font-weight: 600; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.5px; margin: 0 0 14px; } } .format-select { position: relative; /* margin-bottom 移到 .setting-section */ .select-trigger { width: 100%; padding: 10px 16px; border: 1px solid var(--border-color); border-radius: 9999px; /* Rounded pill shape */ font-size: 14px; background: var(--bg-primary); color: var(--text-primary); display: flex; align-items: center; justify-content: space-between; gap: 8px; cursor: pointer; transition: all 0.2s; &:hover { border-color: var(--text-tertiary); } &.open { border-color: var(--primary); box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 15%, transparent); } } .select-value { flex: 1; min-width: 0; text-align: left; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .select-dropdown { position: absolute; top: calc(100% + 6px); left: 0; right: 0; background: color-mix(in srgb, var(--bg-primary) 85%, var(--bg-secondary)); border: 1px solid var(--border-color); border-radius: 12px; padding: 6px; box-shadow: var(--shadow-md); z-index: 20; max-height: 260px; overflow-y: auto; backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); } .select-option { width: 100%; text-align: left; display: flex; flex-direction: column; gap: 4px; padding: 10px 12px; border: none; border-radius: 10px; background: transparent; cursor: pointer; transition: all 0.15s; color: var(--text-primary); font-size: 14px; &:hover { background: var(--bg-tertiary); } &.active { background: color-mix(in srgb, var(--primary) 12%, transparent); color: var(--primary); .option-desc { color: var(--primary); } } } .option-label { font-weight: 500; } .option-desc { font-size: 12px; color: var(--text-tertiary); } } .checkbox-item { display: flex; align-items: center; gap: 10px; cursor: pointer; font-size: 14px; color: var(--text-primary); input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--primary); cursor: pointer; } } .export-path-display { display: flex; align-items: center; gap: 10px; padding: 12px 16px; background: var(--bg-secondary); border-radius: 10px; font-size: 13px; color: var(--text-primary); margin-bottom: 12px; svg { color: var(--primary); flex-shrink: 0; } span { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } } .select-folder-btn { width: 100%; display: flex; align-items: center; justify-content: center; gap: 8px; padding: 10px 16px; background: var(--bg-secondary); border: 1px solid var(--border-color); border-radius: 8px; font-size: 13px; font-weight: 500; color: var(--text-primary); cursor: pointer; transition: all 0.2s; &:hover { background: var(--bg-hover); border-color: var(--primary); color: var(--primary); svg { color: var(--primary); } } &:active { transform: scale(0.98); } svg { color: var(--text-secondary); transition: color 0.2s; } } .export-action { padding: 20px 24px; border-top: 1px solid var(--border-color); } .export-btn { width: 100%; display: flex; align-items: center; justify-content: center; gap: 10px; padding: 14px 24px; background: var(--primary); color: #fff; border: none; border-radius: 12px; font-size: 15px; font-weight: 600; cursor: pointer; transition: all 0.2s; &:hover:not(:disabled) { background: var(--primary-hover); } &:disabled { opacity: 0.5; cursor: not-allowed; } .spin { animation: contactsSpin 1s linear infinite; } } } @keyframes contactsSpin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }