/* /h5/me/* 子页共用（配合 discover_home.css + message_hub.css） */

.me-profile-card {
    background: var(--disc-card);
    border-radius: var(--disc-radius);
    border: 1px solid var(--disc-line);
    padding: 16px 16px 14px;
    margin: 0 0 6px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}

.me-profile-card .disc-skel {
    height: 14px;
    margin-bottom: 8px;
    max-width: 220px;
}

.me-profile-card .disc-skel:last-child {
    max-width: 280px;
    margin-bottom: 0;
}

.me-profile-ok-name {
    font-size: 18px;
    font-weight: 700;
    color: var(--disc-text);
    margin: 0;
    letter-spacing: -0.3px;
}

.me-profile-ok-meta {
    font-size: 13px;
    color: var(--disc-sub);
    line-height: 1.5;
    margin: 8px 0 0;
}

.me-profile-ok-row {
    display: flex;
    align-items: center;
    gap: 12px;
}

.me-profile-avatar-link {
    position: relative;
    width: 72px;
    height: 72px;
    border-radius: 12px;
    overflow: hidden;
    text-decoration: none;
    border: 1px solid var(--disc-line);
    background: #f8f8f8;
    flex: 0 0 72px;
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.05);
}

.me-profile-avatar {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.me-profile-avatar-fallback {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #999;
    font-size: 24px;
}

.me-profile-avatar-badge {
    position: absolute;
    right: -1px;
    bottom: -1px;
    width: 22px;
    height: 22px;
    border-radius: 999px;
    border: 2px solid #fff;
    background: #ff7a7a;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    line-height: 1;
    box-shadow: 0 2px 6px rgba(255, 103, 103, 0.35);
}

.me-profile-ok-main {
    min-width: 0;
    flex: 1 1 auto;
}

.me-profile-card .disc-empty {
    margin: 0;
    padding: 20px 12px;
}

.me-shell-card {
    background: var(--disc-card);
    border-radius: var(--disc-radius);
    border: 1px solid var(--disc-line);
    padding: 16px;
    margin: 0 0 12px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}

.me-shell-card > :first-child {
    margin-top: 0;
}

.me-shell-card > :last-child {
    margin-bottom: 0;
}

.me-field {
    margin-bottom: 14px;
}

.me-field label {
    display: block;
    font-size: 13px;
    color: var(--disc-sub);
    margin-bottom: 6px;
}

.me-field input[type='text'],
.me-field input[type='number'],
.me-field input[type='file'],
.me-field textarea,
.me-field select {
    width: 100%;
    box-sizing: border-box;
    padding: 12px 14px;
    border-radius: 10px;
    border: 1px solid var(--disc-line);
    font-size: 15px;
    font-family: inherit;
}

.me-field textarea {
    min-height: 88px;
    resize: vertical;
}

.me-check-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: var(--disc-text);
    cursor: pointer;
}

.me-plain-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.me-plain-list > li {
    background: var(--disc-card);
    border: 1px solid var(--disc-line);
    border-radius: var(--disc-radius);
    padding: 14px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}

.me-plain-list a {
    color: inherit;
    text-decoration: none;
}

.me-err-banner {
    display: none;
    margin-top: 12px;
    padding: 10px 14px;
    border-radius: 10px;
    background: rgba(255, 103, 103, 0.12);
    color: #b00020;
    font-size: 14px;
    line-height: 1.4;
}

.me-err-banner.is-on {
    display: block;
}

.me-err-banner.is-ok {
    background: rgba(46, 160, 67, 0.12);
    color: #1a7f37;
}

.me-ok-banner {
    display: none;
    margin-top: 12px;
    padding: 10px 14px;
    border-radius: 10px;
    background: rgba(46, 160, 67, 0.12);
    color: #1a7f37;
    font-size: 14px;
}

.me-ok-banner.is-on {
    display: block;
}

.me-hint {
    font-size: 12px;
    color: var(--disc-sub);
    line-height: 1.5;
    margin: 10px 0 0;
}

.me-hint a {
    color: var(--disc-primary);
    font-weight: 500;
    text-decoration: none;
}

.me-wallet-quick {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
    margin-top: 14px;
    font-size: 13px;
}

.me-wallet-quick a {
    color: var(--disc-primary);
    text-decoration: none;
    font-weight: 500;
}

.me-dating-card {
    text-align: center;
}

.me-dating-card .me-avatar {
    width: 96px;
    height: 96px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--disc-line);
}

.me-photo-block {
    margin-bottom: 14px;
    border: 1px solid var(--disc-line);
    padding: 12px;
    border-radius: var(--disc-radius);
    background: #fafafa;
}

.me-photo-block img {
    max-width: 100%;
    border-radius: 8px;
    vertical-align: middle;
}

.me-photo-actions {
    margin-top: 10px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.me-steps-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-height: 280px;
    overflow-y: auto;
}

.me-steps-list li {
    padding: 8px 10px;
    border-radius: 8px;
    border: 1px solid var(--disc-line);
    font-size: 14px;
    background: var(--disc-card);
}

.me-settings-submenu .msg-hub-menu {
    margin-bottom: 8px;
}

.me-legal-block {
    font-size: 14px;
    line-height: 1.6;
    color: #333;
}

.me-legal-block code {
    font-size: 12px;
}

/* 通用 H5：旧版 .card 在 disc-root 内与 me-shell-card 一致 */
.disc-root .card {
    background: var(--disc-card);
    border-radius: var(--disc-radius);
    border: 1px solid var(--disc-line);
    padding: 16px;
    margin-bottom: 12px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}

.disc-root .card label {
    display: block;
    font-size: 13px;
    color: var(--disc-sub);
    margin: 10px 0 6px;
}

.disc-root .card input[type='text'],
.disc-root .card input[type='tel'],
.disc-root .card input[type='number'],
.disc-root .card textarea,
.disc-root .card select {
    width: 100%;
    box-sizing: border-box;
    padding: 12px 14px;
    border-radius: 10px;
    border: 1px solid var(--disc-line);
    font-size: 15px;
    font-family: inherit;
}
