/**
 * 千面 (Persons) - Glimmer Archive 玫瑰贝母粉主题
 * 移植自 美化/美化/千面user.html
 */

/* ========== 🌸 玫瑰贝母粉色系变量 ========== */
.persons-page,
.personas-edit-page {
    --ps-bg: #FCF8F9;
    --ps-bg2: #F7EAEC;
    --ps-white: #FFFFFF;
    --ps-frost: #FDF5F7;
    --ps-pink-dk: #D4798D;
    --ps-pink-md: #E5A9B4;
    --ps-pink-lt: #F7D4DA;
    --ps-txt: #5C3A41;
    --ps-txt-md: #825C65;
    --ps-txt-lt: #B598A0;
    --ps-line: rgba(212,121,141,0.15);
    --ps-sh1: 0 2px 10px rgba(212,121,141,0.05);
    --ps-sh2: 0 6px 20px rgba(212,121,141,0.08);
    --ps-sh3: 0 16px 40px rgba(212,121,141,0.12);
}

/* ========== 千面列表页 ========== */
.persons-page {
    background: var(--ps-bg) !important;
    height: 100% !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    position: relative !important;
    z-index: 10000 !important; /* 🔧 确保在定位面板之上 */
}

/* 确保千面页面在定位面板之上 */
.persons-page.active,
#persons.active,
#persons[style*="flex"],
#persons:not([style*="none"]) {
    z-index: 10000 !important;
}

/* 编辑页完全覆盖列表页 */
#persons-edit {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 300 !important;
    background: var(--ps-bg, #FCF8F9) !important;
}

#persons-edit[style*="none"] {
    display: none !important;
}

#persons-edit[style*="flex"],
#persons-edit.active {
    display: flex !important;
}

.persons-page .header {
    background: rgba(252,248,249,0.85) !important;
    backdrop-filter: blur(28px) !important;
    -webkit-backdrop-filter: blur(28px) !important;
    border-bottom: 1px solid var(--ps-line) !important;
    padding: 16px 20px !important;
}

.persons-page .header-title {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 20px !important;
    font-weight: 500 !important;
    font-style: italic !important;
    color: var(--ps-txt) !important;
    letter-spacing: 1px !important;
}

.persons-page .circle-btn {
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    background: transparent !important;
    border: 1px solid transparent !important;
    color: var(--ps-pink-dk) !important;
    transition: all 0.25s !important;
}

.persons-page .circle-btn:hover {
    background: var(--ps-white) !important;
    border-color: var(--ps-pink-lt) !important;
    box-shadow: var(--ps-sh1) !important;
}

.persons-page .circle-btn.btn-primary {
    background: var(--ps-pink-dk) !important;
    color: #FFF !important;
    border-color: var(--ps-pink-dk) !important;
    box-shadow: 0 4px 12px rgba(212,121,141,0.25) !important;
}

/* ========== 画廊 Hero 区域 ========== */
.persons-page .ps-gallery-hero {
    padding: 36px 24px 28px;
    text-align: center;
    position: relative;
}

.persons-page .ps-gallery-hero::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 24px;
    right: 24px;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--ps-pink-md), transparent);
    opacity: 0.5;
}

.persons-page .ps-hero-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 28px;
    font-weight: 400;
    font-style: italic;
    color: var(--ps-txt);
    letter-spacing: 2px;
    margin-bottom: 6px;
}

.persons-page .ps-hero-sub {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 4px;
    color: var(--ps-txt-lt);
    text-transform: uppercase;
}

/* ========== 双列网格布局 (覆盖旧版横滑样式) ========== */
.persons-page .ps-grid,
.persons-page #persons-list,
#persons-list.ps-grid {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 16px !important;
    padding: 20px !important;
    overflow-x: visible !important;
    overflow-y: auto !important;
    height: auto !important;
    scroll-snap-type: none !important;
    align-items: start !important;
}

/* ========== 卡片样式 ========== */
.persons-page .ps-card {
    background: rgba(255,255,255,0.85) !important;
    overflow: visible !important;
    position: relative !important;
    cursor: pointer !important;
    transition: all 0.4s cubic-bezier(0.25,0.46,0.45,0.94) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    padding: 0 0 20px !important;
    border: 1px solid var(--ps-pink-lt) !important;
    border-radius: 16px !important;
    box-shadow: var(--ps-sh1) !important;
    backdrop-filter: blur(8px) !important;
}

.persons-page .ps-card:hover {
    transform: translateY(-6px) !important;
    box-shadow: var(--ps-sh3) !important;
    border-color: var(--ps-pink-md) !important;
    background: #FFF !important;
}

.persons-page .ps-card-inner {
    width: 100%;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    border-radius: 16px;
}

.persons-page .ps-card-banner {
    width: 100%;
    height: 70px;
    background: linear-gradient(135deg, var(--ps-frost), var(--ps-pink-lt));
    position: relative;
}

/* ========== 👑 动态头像外圈光晕 ========== */
.persons-page .ps-card-avatar-wrap {
    position: relative;
    width: 66px;
    height: 66px;
    border-radius: 50%;
    margin-top: -33px;
    padding: 3px;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--ps-pink-lt), var(--ps-white), var(--ps-pink-dk));
    box-shadow: 0 4px 16px rgba(212,121,141,0.2);
    transition: transform 0.4s;
}

.persons-page .ps-card-avatar-wrap::before {
    content: '';
    position: absolute;
    inset: -1px;
    border-radius: 50%;
    background: conic-gradient(from 0deg, var(--ps-pink-md), #FFF, var(--ps-pink-dk), #FFF, var(--ps-pink-md));
    z-index: -1;
    animation: ps-spin 4s linear infinite;
    opacity: 0.8;
}

@keyframes ps-spin {
    100% { transform: rotate(360deg); }
}

.persons-page .ps-card-avatar {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    border: 2px solid var(--ps-white);
    object-fit: cover;
    background: var(--ps-white);
}

.persons-page .ps-card:hover .ps-card-avatar-wrap {
    transform: scale(1.08);
}

.persons-page .ps-card-name {
    font-size: 15px;
    font-weight: 700;
    color: var(--ps-txt);
    margin-top: 12px;
    margin-bottom: 2px;
    letter-spacing: 1px;
}

.persons-page .ps-card-label {
    font-family: 'Cormorant Garamond', serif;
    font-size: 11px;
    font-weight: 500;
    font-style: italic;
    color: var(--ps-pink-dk);
    letter-spacing: 1px;
    display: flex;
    align-items: center;
    gap: 4px;
}

/* ========== 删除按钮 ========== */
.persons-page .ps-del-x {
    position: absolute;
    top: -8px;
    right: -8px;
    width: 24px;
    height: 24px;
    background: linear-gradient(135deg, #FF4B72, #C2185B);
    color: #FFF;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: bold;
    border: 2px solid var(--ps-white);
    box-shadow: 0 4px 10px rgba(194, 24, 91, 0.3);
    opacity: 0;
    pointer-events: none;
    transition: all 0.25s;
    z-index: 10;
    cursor: pointer;
}

.persons-page .ps-grid.managing .ps-card {
    animation: ps-rock 0.4s infinite alternate ease-in-out;
}

.persons-page .ps-grid.managing .ps-card:nth-child(even) {
    animation-delay: 0.1s;
}

.persons-page .ps-grid.managing .ps-card:hover {
    transform: none !important;
}

.persons-page .ps-grid.managing .ps-del-x {
    opacity: 1;
    pointer-events: auto;
}

.persons-page .ps-del-x:hover {
    transform: scale(1.15) rotate(90deg);
}

@keyframes ps-rock {
    0% { transform: rotate(-1deg); }
    100% { transform: rotate(1deg); }
}

/* ========== 管理浮动按钮 ========== */
.persons-page .ps-mgr-float {
    position: fixed;
    bottom: 100px;
    left: 50%;
    z-index: 500;
    opacity: 0;
    pointer-events: none;
    transform: translateX(-50%) translateY(20px);
    transition: all 0.35s cubic-bezier(0.16,1,0.3,1);
}

.persons-page .ps-mgr-float.show {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}

.persons-page .ps-mgr-float button {
    padding: 14px 48px;
    border-radius: 50px;
    border: none;
    background: var(--ps-pink-dk);
    color: #FFF;
    font-family: 'Noto Sans SC', sans-serif;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 2px;
    cursor: pointer;
    box-shadow: var(--ps-sh3);
    transition: all 0.2s;
}

.persons-page .ps-mgr-float button:hover {
    background: var(--ps-txt);
}

/* ========== 菜单样式 ========== */
.persons-page .ps-menu {
    position: absolute;
    top: 58px;
    right: 16px;
    background: var(--ps-white);
    border-radius: 14px;
    padding: 6px;
    width: 180px;
    box-shadow: var(--ps-sh3);
    border: 1px solid var(--ps-line);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-6px);
    transition: all 0.2s cubic-bezier(0.16,1,0.3,1);
    z-index: 200;
}

.persons-page .ps-menu.active {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.persons-page .ps-menu-item {
    padding: 12px 14px;
    font-size: 13px;
    font-weight: 600;
    color: var(--ps-txt);
    display: flex;
    align-items: center;
    gap: 8px;
    border-radius: 10px;
    cursor: pointer;
    transition: background 0.15s;
}

.persons-page .ps-menu-item:hover {
    background: var(--ps-frost);
    color: var(--ps-pink-dk);
}

.persons-page .ps-menu-item.danger {
    color: #C2185B;
}

.persons-page .ps-menu-item.danger:hover {
    background: #FFF0F5;
}

/* ========== 编辑页样式 ========== */
.personas-edit-page {
    background: var(--ps-bg) !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 10001 !important; /* 🔧 比列表页高 */
}

.personas-edit-page .edit-content-wrapper {
    flex: 1 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-bottom: 100px !important;
}

/* 编辑页导航栏 - 与列表页一致 */
.personas-edit-page .header {
    background: rgba(252,248,249,0.85) !important;
    backdrop-filter: blur(28px) !important;
    -webkit-backdrop-filter: blur(28px) !important;
    border-bottom: 1px solid var(--ps-line) !important;
    padding: 16px 20px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 100 !important;
}

.personas-edit-page .header-title {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 20px !important;
    font-weight: 500 !important;
    font-style: italic !important;
    color: var(--ps-txt) !important;
    letter-spacing: 1px !important;
}

.personas-edit-page .circle-btn {
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    background: transparent !important;
    border: 1px solid transparent !important;
    color: var(--ps-pink-dk) !important;
    transition: all 0.25s !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    font-size: 20px !important;
}

.personas-edit-page .circle-btn:hover {
    background: var(--ps-white) !important;
    border-color: var(--ps-pink-lt) !important;
    box-shadow: var(--ps-sh1) !important;
}

/* ========== 身份切换开关 ========== */
.personas-edit-page .ps-id-switch {
    margin: 20px 24px;
    background: rgba(255,255,255,0.9);
    border-radius: 16px;
    padding: 16px 20px;
    border: 1px solid var(--ps-pink-lt);
    box-shadow: var(--ps-sh1);
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: all 0.3s;
}

.personas-edit-page .ps-id-switch.active {
    border-color: var(--ps-pink-md);
    box-shadow: var(--ps-sh2);
    background: var(--ps-frost);
}

.personas-edit-page .ps-sw-text {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.personas-edit-page .ps-sw-title {
    font-size: 14px;
    font-weight: 700;
    color: var(--ps-pink-dk);
    display: flex;
    align-items: center;
    gap: 6px;
}

.personas-edit-page .ps-sw-sub {
    font-size: 11px;
    color: var(--ps-txt-lt);
}

.personas-edit-page .ps-tgl-btn {
    width: 44px;
    height: 24px;
    background: var(--ps-bg2);
    border-radius: 24px;
    position: relative;
    cursor: pointer;
    transition: all 0.3s;
    box-shadow: inset 0 2px 4px rgba(212,121,141,0.1);
    border: 1px solid var(--ps-pink-lt);
}

.personas-edit-page .ps-tgl-btn::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: 18px;
    height: 18px;
    background: #FFF;
    border-radius: 50%;
    box-shadow: 0 2px 6px rgba(212,121,141,0.3);
    transition: all 0.3s;
}

.personas-edit-page .ps-id-switch.active .ps-tgl-btn {
    background: var(--ps-pink-md);
    border-color: var(--ps-pink-dk);
}

.personas-edit-page .ps-id-switch.active .ps-tgl-btn::after {
    transform: translateX(20px);
}

/* ========== Section 样式 ========== */
.personas-edit-page .ps-sec {
    background: rgba(255,255,255,0.85);
    border-bottom: 1px solid var(--ps-line);
}

.personas-edit-page .ps-sec-head {
    padding: 24px 24px 0;
    display: flex;
    align-items: baseline;
    gap: 12px;
    margin-bottom: 20px;
}

.personas-edit-page .ps-sec-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 32px;
    font-weight: 300;
    font-style: italic;
    color: var(--ps-pink-md);
    line-height: 1;
}

.personas-edit-page .ps-sec-label {
    font-family: 'Cormorant Garamond', serif;
    font-size: 16px;
    font-weight: 600;
    color: var(--ps-txt);
    letter-spacing: 1px;
}

.personas-edit-page .ps-sec-body {
    padding: 0 24px 28px;
}

.personas-edit-page .ps-sec-sub {
    background: rgba(253,245,247,0.85);
    border-bottom: 1px solid var(--ps-line);
}

.personas-edit-page .ps-sec-sub .ps-sec-head {
    padding: 20px 24px 0;
    margin-bottom: 16px;
}

.personas-edit-page .ps-sec-sub .ps-sec-num {
    font-size: 24px;
    color: var(--ps-txt-lt);
}

.personas-edit-page .ps-sec-sub .ps-sec-label {
    font-size: 14px;
    color: var(--ps-txt-md);
}

.personas-edit-page .ps-sec-sub .ps-sec-body {
    padding: 0 24px 24px;
}

/* ========== 表单字段 ========== */
.personas-edit-page .ps-field {
    margin-bottom: 16px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.personas-edit-page .ps-field-label {
    font-size: 11px;
    font-weight: 700;
    color: var(--ps-txt-lt);
    letter-spacing: 1px;
    text-transform: uppercase;
}

.personas-edit-page textarea,
.personas-edit-page input[type="text"] {
    width: 100%;
    background: var(--ps-bg) !important;
    border: 1px solid var(--ps-pink-lt) !important;
    border-radius: 10px !important;
    padding: 12px 14px !important;
    font-size: 13px !important;
    color: var(--ps-txt) !important;
    transition: all 0.25s !important;
    resize: none;
    line-height: 1.6;
    font-family: inherit;
    font-weight: 500;
}

/* 自适应文本框 - 支持框内滚动 */
.personas-edit-page textarea.auto-resize {
    min-height: 52px;
    max-height: 200px;  /* 🔧 限制最大高度，超出后可滚动 */
    overflow-y: auto;   /* 🔧 内容超出时显示滚动条 */
}

.personas-edit-page .ps-sec-sub textarea,
.personas-edit-page .ps-sec-sub input[type="text"] {
    background: var(--ps-white) !important;
}

.personas-edit-page textarea:focus,
.personas-edit-page input[type="text"]:focus {
    border-color: var(--ps-pink-dk) !important;
    background: #FFF !important;
    box-shadow: 0 0 0 3px rgba(247, 212, 218, 0.3) !important;
}

.personas-edit-page textarea::placeholder,
.personas-edit-page input[type="text"]::placeholder {
    color: var(--ps-txt-lt) !important;
    font-weight: 400;
}

/* ========== 👑 动态流光自转头像框 ========== */
.personas-edit-page .ps-av-wrap {
    position: relative;
    border-radius: 50%;
    padding: 4px;
    background: transparent;
    box-shadow: 0 6px 16px rgba(212,121,141,0.2);
    flex-shrink: 0;
    z-index: 1;
    display: flex;
    justify-content: center;
    align-items: center;
}

.personas-edit-page .ps-av-wrap::before {
    content: '';
    position: absolute;
    inset: -1px;
    border-radius: 50%;
    background: conic-gradient(from 0deg, var(--ps-pink-md), #FFF, var(--ps-pink-dk), #FFF, var(--ps-pink-md));
    z-index: -1;
    animation: ps-spin 4s linear infinite;
}

.personas-edit-page .ps-av-wrap img {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--ps-white);
    background: var(--ps-bg);
    position: relative;
    z-index: 2;
}

.personas-edit-page .ps-av-row {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 24px;
}

.personas-edit-page .ps-av-row .ps-av-wrap {
    width: 76px;
    height: 76px;
}

/* ========== 按钮样式 ========== */
.personas-edit-page .ps-btn-o {
    padding: 8px 14px;
    background: var(--ps-white);
    border: 1px solid var(--ps-pink-lt);
    border-radius: 8px;
    color: var(--ps-pink-dk);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}

.personas-edit-page .ps-btn-o:hover {
    background: var(--ps-pink-dk);
    color: #FFF;
    border-color: var(--ps-pink-dk);
    box-shadow: var(--ps-sh1);
}

/* ========== Digital ID 区域 ========== */
.personas-edit-page .ps-did-box {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding-top: 10px;
}

.personas-edit-page .ps-did-box .ps-av-wrap {
    width: 84px;
    height: 84px;
}

.personas-edit-page .ps-mini-group {
    display: flex;
    gap: 12px;
    margin-top: 8px;
}

.personas-edit-page .ps-mini-circle {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--ps-white);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ps-pink-dk);
    font-size: 14px;
    cursor: pointer;
    transition: all 0.2s;
    border: 1px solid var(--ps-pink-lt);
    box-shadow: var(--ps-sh1);
}

.personas-edit-page .ps-mini-circle:hover {
    background: var(--ps-pink-dk);
    color: #FFF;
    border-color: var(--ps-pink-dk);
    transform: translateY(-3px);
}

/* ========== 底部保存栏 ========== */
.personas-edit-page .save-bar {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    width: 100% !important;
    padding: 12px 20px 24px !important;
    background: linear-gradient(to top, rgba(255,255,255,0.95) 50%, transparent) !important;
    display: flex !important;
    justify-content: center !important;
    z-index: 100 !important;
    gap: 12px !important;
}

.personas-edit-page .save-bar .btn-main {
    flex: 1 !important;
    max-width: 240px !important;
    padding: 14px !important;
    border-radius: 16px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    border: none !important;
    transition: all 0.2s !important;
    letter-spacing: 2px !important;
}

.personas-edit-page .save-bar .btn-main:first-child {
    background: var(--ps-frost) !important;
    color: var(--ps-txt-lt) !important;
    border: 1px solid var(--ps-pink-lt) !important;
}

.personas-edit-page .save-bar .btn-main:last-child {
    background: linear-gradient(135deg, var(--ps-pink-md), var(--ps-pink-dk)) !important;
    color: #FFF !important;
    box-shadow: 0 8px 20px rgba(212,121,141,0.3) !important;
}

.personas-edit-page .save-bar .btn-main:last-child:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 10px 24px rgba(212,121,141,0.4) !important;
}

/* ========== 弹窗样式 ========== */
.ps-overlay {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(92,58,65,0.2) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 10000 !important;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s;
}

.persons-page .ps-overlay.active,
.personas-edit-page .ps-overlay.active {
    opacity: 1;
    pointer-events: auto;
}

.persons-page .ps-mdl,
.personas-edit-page .ps-mdl {
    width: 280px;
    background: rgba(255,255,255,0.95);
    border-radius: 20px;
    padding: 24px;
    transform: scale(0.95) translateY(10px);
    transition: all 0.3s cubic-bezier(0.16,1,0.3,1);
    box-shadow: var(--ps-sh3);
    border: 1px solid var(--ps-white);
}

.persons-page .ps-overlay.active .ps-mdl,
.personas-edit-page .ps-overlay.active .ps-mdl {
    transform: scale(1) translateY(0);
}

.persons-page .ps-mdl h3,
.personas-edit-page .ps-mdl h3 {
    font-size: 15px;
    color: var(--ps-pink-dk);
    margin-bottom: 16px;
    text-align: center;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}

.persons-page .ps-mdl-input,
.personas-edit-page .ps-mdl-input {
    width: 100%;
    padding: 12px 14px;
    border-radius: 10px;
    border: 1px solid var(--ps-pink-lt);
    background: var(--ps-bg);
    font-family: inherit;
    font-size: 13px;
    color: var(--ps-txt);
    outline: none;
    transition: border-color 0.25s;
    text-align: center;
    font-weight: 600;
}

.persons-page .ps-mdl-input:focus,
.personas-edit-page .ps-mdl-input:focus {
    border-color: var(--ps-pink-dk);
    background: #FFF;
}

.persons-page .ps-mdl-btns,
.personas-edit-page .ps-mdl-btns {
    display: flex;
    gap: 10px;
    margin-top: 16px;
}

.persons-page .ps-mb,
.personas-edit-page .ps-mb {
    flex: 1;
    padding: 12px;
    border-radius: 10px;
    border: none;
    font-weight: 600;
    cursor: pointer;
    font-size: 13px;
    transition: all 0.2s;
}

.persons-page .ps-mb-no,
.personas-edit-page .ps-mb-no {
    background: var(--ps-frost);
    color: var(--ps-txt-lt);
    border: 1px solid var(--ps-pink-lt);
}

.persons-page .ps-mb-no:hover,
.personas-edit-page .ps-mb-no:hover {
    background: var(--ps-white);
    color: var(--ps-pink-dk);
}

.persons-page .ps-mb-yes,
.personas-edit-page .ps-mb-yes {
    background: var(--ps-pink-dk);
    color: #FFF;
}

.persons-page .ps-mb-yes:hover,
.personas-edit-page .ps-mb-yes:hover {
    transform: translateY(-2px);
    box-shadow: var(--ps-sh2);
}

/* ========== Toast 样式 ========== */
.persons-page .ps-toast,
.personas-edit-page .ps-toast {
    background: rgba(255,255,255,0.95) !important;
    padding: 12px 24px !important;
    border-radius: 20px !important;
    border: 1px solid var(--ps-pink-lt) !important;
    box-shadow: var(--ps-sh2) !important;
    color: var(--ps-pink-dk) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    letter-spacing: 0.5px !important;
    backdrop-filter: blur(8px) !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
}

/* ========== 空状态 ========== */
.persons-page .empty-state {
    text-align: center;
    padding: 60px 20px;
    color: var(--ps-txt-lt);
}

.persons-page .empty-state i {
    font-size: 48px;
    color: var(--ps-pink-lt);
    margin-bottom: 16px;
}

.persons-page .empty-state p {
    margin: 8px 0;
}

.persons-page .empty-state .hint {
    font-size: 12px;
    color: var(--ps-txt-lt);
}
