.pwd-rules {
    list-style: none;
    margin: 0;
    padding: 12px 14px;
    display: grid;
    gap: 6px;
    background: #f8fafc;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
}

.pwd-rules li {
    position: relative;
    padding-left: 24px;
    font-size: 0.85rem;
    color: #6b7280;
    line-height: 1.4;
    transition: color 200ms ease;
}

.pwd-rules li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: #e5e7eb;
    transition: background 200ms ease;
}

.pwd-rules li::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 50%;
    width: 6px;
    height: 3px;
    border-left: 2px solid transparent;
    border-bottom: 2px solid transparent;
    transform: translateY(-65%) rotate(-45deg);
    transition: border-color 200ms ease;
}

.pwd-rules li.is-met {
    color: #047857;
}

.pwd-rules li.is-met::before {
    background: #10b981;
}

.pwd-rules li.is-met::after {
    border-color: #ffffff;
}
