/* ── PersonCard — global (component-level CSS) ── */

.person-card {
    border: 1.5px solid var(--color-gray-400);
    border-radius: 12px;
    overflow: hidden;
    background: var(--color-gray-50);
    transition: box-shadow 0.25s ease;
}

.person-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

body.dark .person-card {
    border-color: var(--color-gray-700);
    background: var(--color-dark-surface);
}

body.dark .person-card:hover {
    box-shadow: 0 4px 16px rgba(255, 255, 255, 0.04);
}

.person-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--color-gray-400);
    background: var(--color-primary-50);
}

body.dark .person-card-header {
    border-bottom-color: var(--color-gray-700);
    background: var(--color-dark-surface);
}

.person-role {
    font-weight: 700;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.person-role.owner {
    color: var(--color-primary-700);
}

.person-role.tenant {
    color: var(--color-success);
}

body.dark .person-role.owner {
    color: var(--color-primary-100);
}

body.dark .person-role.tenant {
    color: var(--color-success);
}

.btn-edit {
    flex-shrink: 0;
}

.person-card-body {
    padding: 1rem;
}

.person-name {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--color-gray-900);
    margin-bottom: 0.25rem;
}

body.dark .person-name {
    color: var(--color-dark-text-primary);
}

.person-cpf {
    font-size: 0.85rem;
    color: var(--color-gray-700);
    font-family: 'Courier New', monospace;
}

body.dark .person-cpf {
    color: var(--color-gray-400);
}

.person-since {
    font-size: 0.82rem;
    color: var(--color-gray-700);
    margin-top: 0.3rem;
}

body.dark .person-since {
    color: var(--color-gray-400);
}

.contact-list {
    margin-top: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    border-top: 1px solid var(--color-gray-400);
    padding-top: 0.75rem;
}

body.dark .contact-list {
    border-top-color: var(--color-gray-700);
}

.contact-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.88rem;
}

.contact-label {
    font-weight: 600;
    color: var(--color-gray-700);
    white-space: nowrap;
    min-width: 80px;
}

body.dark .contact-label {
    color: var(--color-gray-400);
}

.contact-value {
    color: var(--color-gray-900);
    word-break: break-all;
}

body.dark .contact-value {
    color: var(--color-dark-text-primary);
}

.person-card-empty {
    padding: 1.5rem 1rem;
    text-align: center;
    color: var(--color-gray-400);
    font-style: italic;
    font-size: 0.9rem;
}

body.dark .person-card-empty {
    color: var(--color-gray-700);
}

.delegation-section {
    margin-top: 0.75rem;
    border-top: 1px dashed var(--color-gray-400);
    padding-top: 0.75rem;
}

body.dark .delegation-section {
    border-top-color: var(--color-gray-700);
}

.delegation-title {
    font-size: 0.82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-primary-500);
    margin-bottom: 0.5rem;
}

body.dark .delegation-title {
    color: var(--color-primary-300);
}

.btn-add-delegation {
    margin-top: 0.75rem;
}
