/* ==========================================================================
   Payment Status Indicator (dot)
   ========================================================================== */
.payment-status {
    text-transform: uppercase;
}

.payment-indicator {
    border-radius: 50%;
    display: inline-block;
    width: 0.5rem;
    height: 0.5rem;
    font-size: 0.75rem;
    letter-spacing: 0.05rem;
}

.payment-status.paid .payment-indicator {
    background-color: #1ac64d;
}

.payment-status.pending .payment-indicator {
    background-color: #f29e54;
}

.payment-status.overdue .payment-indicator {
    background-color: #ff5050;
}

/* ==========================================================================
   Payment Status Badge (pill style for DataTable cells)
   ========================================================================== */
.payment-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    white-space: nowrap;
}

.payment-badge .payment-dot {
    width: 0.45rem;
    height: 0.45rem;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}

.payment-badge.badge-paid {
    background: rgba(26, 198, 77, 0.1);
    color: #17a34a;
}

.payment-badge.badge-paid .payment-dot {
    background-color: #1ac64d;
}

.payment-badge.badge-pending {
    background: rgba(242, 158, 84, 0.1);
    color: #d26c05;
}

.payment-badge.badge-pending .payment-dot {
    background-color: #f29e54;
}

.payment-badge.badge-overdue {
    background: rgba(255, 80, 80, 0.1);
    color: #dc2626;
}

.payment-badge.badge-overdue .payment-dot {
    background-color: #ff5050;
}
